2003-04-21 17:37:11 -04:00
< ? php
2008-06-15 05:38:32 -04:00
/**
* Main WordPress API
*
* @ package WordPress
*/
2003-04-21 17:37:11 -04:00
2020-02-06 01:33:11 -05:00
require ABSPATH . WPINC . '/option.php' ;
2016-08-31 11:24:29 -04:00
2008-06-15 05:38:32 -04:00
/**
2022-08-12 05:53:11 -04:00
* Converts given MySQL date string into a different format .
2008-06-15 05:38:32 -04:00
*
2021-10-29 12:51:56 -04:00
* - `$format` should be a PHP date format string .
* - 'U' and 'G' formats will return an integer sum of timestamp with timezone offset .
* - `$date` is expected to be local time in MySQL format ( `Y-m-d H:i:s` ) .
2012-02-21 15:03:11 -05:00
*
2019-08-29 01:07:56 -04:00
* Historically UTC time could be passed to the function to produce Unix timestamp .
*
* If `$translate` is true then the given date and format string will
* be passed to `wp_date()` for translation .
2008-06-15 05:38:32 -04:00
*
* @ since 0.71
*
2014-06-29 23:56:15 -04:00
* @ param string $format Format of the date to return .
* @ param string $date Date string to convert .
* @ param bool $translate Whether the return date should be translated . Default true .
2021-10-29 12:51:56 -04:00
* @ return string | int | false Integer if `$format` is 'U' or 'G' , string otherwise .
2019-08-29 01:07:56 -04:00
* False on failure .
2008-06-15 05:38:32 -04:00
*/
2012-02-21 15:03:11 -05:00
function mysql2date ( $format , $date , $translate = true ) {
2017-11-30 18:11:00 -05:00
if ( empty ( $date ) ) {
2003-04-21 17:37:11 -04:00
return false ;
2017-11-30 18:11:00 -05:00
}
2008-03-02 15:17:30 -05:00
2023-03-10 10:36:20 -05:00
$timezone = wp_timezone ();
$datetime = date_create ( $date , $timezone );
2008-03-02 15:17:30 -05:00
2019-08-29 01:07:56 -04:00
if ( false === $datetime ) {
return false ;
}
2006-02-12 02:53:23 -05:00
2019-08-29 01:07:56 -04:00
// Returns a sum of timestamp with timezone offset. Ideally should never be used.
if ( 'G' === $format || 'U' === $format ) {
return $datetime -> getTimestamp () + $datetime -> getOffset ();
2017-11-30 18:11:00 -05:00
}
2006-11-19 02:56:05 -05:00
2017-11-30 18:11:00 -05:00
if ( $translate ) {
2023-03-10 10:36:20 -05:00
return wp_date ( $format , $datetime -> getTimestamp (), $timezone );
2017-11-30 18:11:00 -05:00
}
2019-08-29 01:07:56 -04:00
return $datetime -> format ( $format );
2003-04-21 17:37:11 -04:00
}
2008-06-15 05:38:32 -04:00
/**
2019-08-19 17:07:50 -04:00
* Retrieves the current time based on specified type .
2008-06-15 05:38:32 -04:00
*
2021-10-29 12:51:56 -04:00
* - The 'mysql' type will return the time in the format for MySQL DATETIME field .
* - The 'timestamp' or 'U' types will return the current timestamp or a sum of timestamp
* and timezone offset , depending on `$gmt` .
* - Other strings will be interpreted as PHP date formats ( e . g . 'Y-m-d' ) .
2008-06-15 05:38:32 -04:00
*
2021-10-29 12:51:56 -04:00
* If `$gmt` is a truthy value then both types will use GMT time , otherwise the
* output is adjusted with the GMT offset for the site .
2008-06-15 05:38:32 -04:00
*
* @ since 1.0 . 0
2021-10-29 12:51:56 -04:00
* @ since 5.3 . 0 Now returns an integer if `$type` is 'U' . Previously a string was returned .
2008-06-15 05:38:32 -04:00
*
2021-10-29 12:51:56 -04:00
* @ param string $type Type of time to retrieve . Accepts 'mysql' , 'timestamp' , 'U' ,
2019-08-29 01:07:56 -04:00
* or PHP date format string ( e . g . 'Y-m-d' ) .
2014-06-29 23:56:15 -04:00
* @ param int | bool $gmt Optional . Whether to use GMT timezone . Default false .
2021-10-29 12:51:56 -04:00
* @ return int | string Integer if `$type` is 'timestamp' or 'U' , string otherwise .
2008-06-15 05:38:32 -04:00
*/
2007-10-11 01:46:57 -04:00
function current_time ( $type , $gmt = 0 ) {
2019-08-19 17:07:50 -04:00
// Don't use non-GMT timestamp, unless you know the difference and really need to.
if ( 'timestamp' === $type || 'U' === $type ) {
Date/Time: Revert [55054].
This changeset introduced a regression for partial-hour timezones such as +05:30 UTC which is India and Sri Lanka. How? These timezones are in float. The change made in [55054] type casted them to integer which dropped the decimal for the partial-hour, making the time inaccurate. For example, +05:30 UTC (India and Sri Lanka)'s `'gmt_offset'` is `5.5`, but with the changeset, it was changed to `5`.
Reverting the changeset restores the original state of `current_time()` and thus resolves the regression.
Props reputeinfosystems, Rarst, hellofromTonya, desrosj, audrasjb, sergeybiryukov, costdev, priethor, francina, nekojonez, codingchicken, cbringmann.
See #57035.
Fixes #57998.
Built from https://develop.svn.wordpress.org/trunk@55598
git-svn-id: http://core.svn.wordpress.org/trunk@55110 1a063a9b-81f0-0310-95a4-ce76da25c4cd
2023-03-28 10:22:21 -04:00
return $gmt ? time () : time () + ( int ) ( get_option ( 'gmt_offset' ) * HOUR_IN_SECONDS );
2003-11-15 03:58:18 -05:00
}
2019-08-19 17:07:50 -04:00
if ( 'mysql' === $type ) {
$type = 'Y-m-d H:i:s' ;
}
$timezone = $gmt ? new DateTimeZone ( 'UTC' ) : wp_timezone ();
$datetime = new DateTime ( 'now' , $timezone );
return $datetime -> format ( $type );
2003-11-15 03:58:18 -05:00
}
2019-08-22 21:12:55 -04:00
/**
2021-10-29 12:51:56 -04:00
* Retrieves the current time as an object using the site ' s timezone .
2019-08-22 21:12:55 -04:00
*
* @ since 5.3 . 0
*
* @ return DateTimeImmutable Date and time object .
*/
function current_datetime () {
return new DateTimeImmutable ( 'now' , wp_timezone () );
}
2008-06-29 23:23:44 -04:00
/**
2021-10-29 12:51:56 -04:00
* Retrieves the timezone of the site as a string .
2019-08-19 15:08:59 -04:00
*
2021-10-29 12:51:56 -04:00
* Uses the `timezone_string` option to get a proper timezone name if available ,
* otherwise falls back to a manual UTC ± offset .
*
* Example return values :
*
* - 'Europe/Rome'
* - 'America/North_Dakota/New_Salem'
* - 'UTC'
* - '-06:30'
* - '+00:00'
* - '+08:45'
2019-08-19 15:08:59 -04:00
*
* @ since 5.3 . 0
*
2021-10-29 12:51:56 -04:00
* @ return string PHP timezone name or a ±HH : MM offset .
2019-08-19 15:08:59 -04:00
*/
function wp_timezone_string () {
$timezone_string = get_option ( 'timezone_string' );
if ( $timezone_string ) {
return $timezone_string ;
}
$offset = ( float ) get_option ( 'gmt_offset' );
$hours = ( int ) $offset ;
$minutes = ( $offset - $hours );
$sign = ( $offset < 0 ) ? '-' : '+' ;
$abs_hour = abs ( $hours );
$abs_mins = abs ( $minutes * 60 );
$tz_offset = sprintf ( '%s%02d:%02d' , $sign , $abs_hour , $abs_mins );
return $tz_offset ;
}
/**
2021-10-29 12:51:56 -04:00
* Retrieves the timezone of the site as a `DateTimeZone` object .
2019-08-19 15:08:59 -04:00
*
* Timezone can be based on a PHP timezone string or a ±HH : MM offset .
*
* @ since 5.3 . 0
*
* @ return DateTimeZone Timezone object .
*/
function wp_timezone () {
return new DateTimeZone ( wp_timezone_string () );
}
/**
* Retrieves the date in localized format , based on a sum of Unix timestamp and
2018-06-27 22:44:12 -04:00
* timezone offset in seconds .
2008-06-29 23:23:44 -04:00
*
* If the locale specifies the locale month and weekday , then the locale will
* take over the format for the date . If it isn ' t , then the date format string
* will be used instead .
*
2019-08-22 20:57:56 -04:00
* Note that due to the way WP typically generates a sum of timestamp and offset
* with `strtotime()` , it implies offset added at a _current_ time , not at the time
* the timestamp represents . Storing such timestamps or calculating them differently
* will lead to invalid output .
*
2008-06-29 23:23:44 -04:00
* @ since 0.71
2019-08-27 20:52:56 -04:00
* @ since 5.3 . 0 Converted into a wrapper for wp_date () .
2008-06-29 23:23:44 -04:00
*
2019-08-27 20:52:56 -04:00
* @ param string $format Format to display the date .
2019-08-29 01:07:56 -04:00
* @ param int | bool $timestamp_with_offset Optional . A sum of Unix timestamp and timezone offset
* in seconds . Default false .
* @ param bool $gmt Optional . Whether to use GMT timezone . Only applies
* if timestamp is not provided . Default false .
2008-06-29 23:23:44 -04:00
* @ return string The date , translated if locale specifies it .
*/
2019-08-27 20:52:56 -04:00
function date_i18n ( $format , $timestamp_with_offset = false , $gmt = false ) {
2019-08-29 19:18:55 -04:00
$timestamp = $timestamp_with_offset ;
2019-08-27 20:52:56 -04:00
// If timestamp is omitted it should be current time (summed with offset, unless `$gmt` is true).
2019-08-29 19:18:55 -04:00
if ( ! is_numeric ( $timestamp ) ) {
2021-08-05 10:49:57 -04:00
// phpcs:ignore WordPress.DateTime.CurrentTimeTimestamp.Requested
2019-08-29 19:18:55 -04:00
$timestamp = current_time ( 'timestamp' , $gmt );
}
2009-04-20 14:18:39 -04:00
2019-08-27 20:52:56 -04:00
/*
* This is a legacy implementation quirk that the returned timestamp is also with offset .
* Ideally this function should never be used to produce a timestamp .
*/
if ( 'U' === $format ) {
$date = $timestamp ;
2019-10-25 07:05:07 -04:00
} elseif ( $gmt && false === $timestamp_with_offset ) { // Current time in UTC.
2019-08-27 20:52:56 -04:00
$date = wp_date ( $format , null , new DateTimeZone ( 'UTC' ) );
2019-10-25 07:05:07 -04:00
} elseif ( false === $timestamp_with_offset ) { // Current time in site's timezone.
2019-08-27 20:52:56 -04:00
$date = wp_date ( $format );
} else {
/*
* Timestamp with offset is typically produced by a UTC `strtotime()` call on an input without timezone .
* This is the best attempt to reverse that operation into a local time to use .
*/
$local_time = gmdate ( 'Y-m-d H:i:s' , $timestamp );
$timezone = wp_timezone ();
$datetime = date_create ( $local_time , $timezone );
$date = wp_date ( $format , $datetime -> getTimestamp (), $timezone );
2011-05-08 13:14:36 -04:00
}
2019-08-27 20:52:56 -04:00
/**
* Filters the date formatted based on the locale .
*
* @ since 2.8 . 0
*
* @ param string $date Formatted date string .
* @ param string $format Format to display the date .
* @ param int $timestamp A sum of Unix timestamp and timezone offset in seconds .
* Might be without offset if input omitted timestamp but requested GMT .
* @ param bool $gmt Whether to use GMT timezone . Only applies if timestamp was not provided .
* Default false .
2014-06-29 23:56:15 -04:00
*/
2019-08-27 20:52:56 -04:00
$date = apply_filters ( 'date_i18n' , $date , $format , $timestamp , $gmt );
2009-04-20 14:18:39 -04:00
2019-08-27 20:52:56 -04:00
return $date ;
}
2018-07-05 19:10:25 -04:00
2019-08-27 20:52:56 -04:00
/**
* Retrieves the date , in localized format .
*
* This is a newer function , intended to replace `date_i18n()` without legacy quirks in it .
*
2019-08-29 01:07:56 -04:00
* Note that , unlike `date_i18n()` , this function accepts a true Unix timestamp , not summed
* with timezone offset .
2019-08-27 20:52:56 -04:00
*
* @ since 5.3 . 0
*
2021-07-01 17:12:58 -04:00
* @ global WP_Locale $wp_locale WordPress date and time locale object .
*
2019-08-27 20:52:56 -04:00
* @ param string $format PHP date format .
* @ param int $timestamp Optional . Unix timestamp . Defaults to current time .
2019-08-29 01:07:56 -04:00
* @ param DateTimeZone $timezone Optional . Timezone to output result in . Defaults to timezone
* from site settings .
2019-08-29 19:18:55 -04:00
* @ return string | false The date , translated if locale specifies it . False on invalid timestamp input .
2019-08-27 20:52:56 -04:00
*/
function wp_date ( $format , $timestamp = null , $timezone = null ) {
global $wp_locale ;
2018-07-03 11:59:25 -04:00
2019-08-29 19:18:55 -04:00
if ( null === $timestamp ) {
2019-08-27 20:52:56 -04:00
$timestamp = time ();
2019-08-29 19:18:55 -04:00
} elseif ( ! is_numeric ( $timestamp ) ) {
return false ;
2019-08-27 20:52:56 -04:00
}
2019-08-22 20:57:56 -04:00
2019-08-27 20:52:56 -04:00
if ( ! $timezone ) {
$timezone = wp_timezone ();
2019-08-22 20:57:56 -04:00
}
2019-08-27 20:52:56 -04:00
$datetime = date_create ( '@' . $timestamp );
$datetime -> setTimezone ( $timezone );
if ( empty ( $wp_locale -> month ) || empty ( $wp_locale -> weekday ) ) {
$date = $datetime -> format ( $format );
} else {
// We need to unpack shorthand `r` format because it has parts that might be localized.
$format = preg_replace ( '/(?<!\\\\)r/' , DATE_RFC2822 , $format );
2019-08-22 20:57:56 -04:00
2019-08-27 20:52:56 -04:00
$new_format = '' ;
$format_length = strlen ( $format );
$month = $wp_locale -> get_month ( $datetime -> format ( 'm' ) );
$weekday = $wp_locale -> get_weekday ( $datetime -> format ( 'w' ) );
2019-08-22 20:57:56 -04:00
2022-11-29 16:13:16 -05:00
for ( $i = 0 ; $i < $format_length ; $i ++ ) {
2019-08-27 20:52:56 -04:00
switch ( $format [ $i ] ) {
2019-08-22 20:57:56 -04:00
case 'D' :
2019-10-22 13:31:08 -04:00
$new_format .= addcslashes ( $wp_locale -> get_weekday_abbrev ( $weekday ), '\\A..Za..z' );
2019-08-22 20:57:56 -04:00
break ;
case 'F' :
2019-10-22 13:31:08 -04:00
$new_format .= addcslashes ( $month , '\\A..Za..z' );
2019-08-22 20:57:56 -04:00
break ;
case 'l' :
2019-10-22 13:31:08 -04:00
$new_format .= addcslashes ( $weekday , '\\A..Za..z' );
2019-08-22 20:57:56 -04:00
break ;
case 'M' :
2019-10-22 13:31:08 -04:00
$new_format .= addcslashes ( $wp_locale -> get_month_abbrev ( $month ), '\\A..Za..z' );
2019-08-22 20:57:56 -04:00
break ;
case 'a' :
2019-10-22 13:31:08 -04:00
$new_format .= addcslashes ( $wp_locale -> get_meridiem ( $datetime -> format ( 'a' ) ), '\\A..Za..z' );
2019-08-22 20:57:56 -04:00
break ;
case 'A' :
2019-10-22 13:31:08 -04:00
$new_format .= addcslashes ( $wp_locale -> get_meridiem ( $datetime -> format ( 'A' ) ), '\\A..Za..z' );
2019-08-22 20:57:56 -04:00
break ;
case '\\' :
2019-08-27 20:52:56 -04:00
$new_format .= $format [ $i ];
2019-08-22 20:57:56 -04:00
// If character follows a slash, we add it without translating.
if ( $i < $format_length ) {
2019-08-27 20:52:56 -04:00
$new_format .= $format [ ++ $i ];
2018-07-03 11:59:25 -04:00
}
2019-08-22 20:57:56 -04:00
break ;
default :
2019-08-27 20:52:56 -04:00
$new_format .= $format [ $i ];
2019-08-22 20:57:56 -04:00
break ;
2018-07-03 11:59:25 -04:00
}
2010-11-05 07:19:06 -04:00
}
2019-08-22 20:57:56 -04:00
2019-08-27 20:52:56 -04:00
$date = $datetime -> format ( $new_format );
2020-01-16 20:12:04 -05:00
$date = wp_maybe_decline_date ( $date , $format );
2019-08-27 20:52:56 -04:00
}
2014-04-13 20:20:14 -04:00
/**
2016-05-22 14:36:27 -04:00
* Filters the date formatted based on the locale .
2014-04-13 20:20:14 -04:00
*
2019-08-27 20:52:56 -04:00
* @ since 5.3 . 0
*
* @ param string $date Formatted date string .
* @ param string $format Format to display the date .
* @ param int $timestamp Unix timestamp .
* @ param DateTimeZone $timezone Timezone .
2014-04-13 20:20:14 -04:00
*/
2019-08-27 20:52:56 -04:00
$date = apply_filters ( 'wp_date' , $date , $format , $timestamp , $timezone );
2019-08-22 20:57:56 -04:00
2019-08-27 20:52:56 -04:00
return $date ;
2006-04-01 19:20:11 -05:00
}
2003-04-21 17:37:11 -04:00
2015-11-04 16:28:26 -05:00
/**
* Determines if the date should be declined .
*
* If the locale specifies that month names require a genitive case in certain
* formats ( like 'j F Y' ), the month name will be replaced with a correct form .
*
* @ since 4.4 . 0
2020-01-16 20:12:04 -05:00
* @ since 5.4 . 0 The `$format` parameter was added .
2015-11-04 16:28:26 -05:00
*
2019-08-03 21:46:55 -04:00
* @ global WP_Locale $wp_locale WordPress date and time locale object .
2017-06-15 08:24:41 -04:00
*
2020-01-16 20:12:04 -05:00
* @ param string $date Formatted date string .
* @ param string $format Optional . Date format to check . Default empty string .
2015-11-04 16:28:26 -05:00
* @ return string The date , declined if locale specifies it .
*/
2020-01-16 20:12:04 -05:00
function wp_maybe_decline_date ( $date , $format = '' ) {
2015-11-04 16:28:26 -05:00
global $wp_locale ;
2020-01-28 19:45:18 -05:00
// i18n functions are not available in SHORTINIT mode.
2015-12-11 20:42:38 -05:00
if ( ! function_exists ( '_x' ) ) {
return $date ;
}
2019-09-02 20:41:05 -04:00
/*
* translators : If months in your language require a genitive case ,
2015-11-04 16:28:26 -05:00
* translate this to 'on' . Do not translate into your own language .
*/
if ( 'on' === _x ( 'off' , 'decline months names: on or off' ) ) {
2019-06-20 09:47:52 -04:00
$months = $wp_locale -> month ;
$months_genitive = $wp_locale -> month_genitive ;
2019-12-09 13:50:06 -05:00
/*
* Match a format like 'j F Y' or 'j. F' ( day of the month , followed by month name )
* and decline the month .
*/
2020-01-16 20:12:04 -05:00
if ( $format ) {
$decline = preg_match ( '#[dj]\.? F#' , $format );
} else {
// If the format is not passed, try to guess it from the date string.
$decline = preg_match ( '#\b\d{1,2}\.? [^\d ]+\b#u' , $date );
}
if ( $decline ) {
2015-11-04 16:28:26 -05:00
foreach ( $months as $key => $month ) {
2019-12-09 13:50:06 -05:00
$months [ $key ] = '# ' . preg_quote ( $month , '#' ) . '\b#u' ;
2015-11-04 16:28:26 -05:00
}
2016-07-05 17:43:30 -04:00
foreach ( $months_genitive as $key => $month ) {
2019-12-09 13:50:06 -05:00
$months_genitive [ $key ] = ' ' . $month ;
2016-07-05 17:43:30 -04:00
}
$date = preg_replace ( $months , $months_genitive , $date );
2015-11-04 16:28:26 -05:00
}
2019-06-20 09:47:52 -04:00
2019-12-09 13:50:06 -05:00
/*
* Match a format like 'F jS' or 'F j' ( month name , followed by day with an optional ordinal suffix )
* and change it to declined 'j F' .
*/
2020-01-16 20:12:04 -05:00
if ( $format ) {
$decline = preg_match ( '#F [dj]#' , $format );
} else {
// If the format is not passed, try to guess it from the date string.
$decline = preg_match ( '#\b[^\d ]+ \d{1,2}(st|nd|rd|th)?\b#u' , trim ( $date ) );
}
if ( $decline ) {
2019-06-20 09:47:52 -04:00
foreach ( $months as $key => $month ) {
2020-01-21 18:48:04 -05:00
$months [ $key ] = '#\b' . preg_quote ( $month , '#' ) . ' (\d{1,2})(st|nd|rd|th)?([-– ]\d{1,2})?(st|nd|rd|th)?\b#u' ;
2019-06-20 09:47:52 -04:00
}
foreach ( $months_genitive as $key => $month ) {
2020-01-21 18:48:04 -05:00
$months_genitive [ $key ] = '$1$3 ' . $month ;
2019-06-20 09:47:52 -04:00
}
$date = preg_replace ( $months , $months_genitive , $date );
}
2015-11-04 16:28:26 -05:00
}
2020-01-28 19:45:18 -05:00
// Used for locale-specific rules.
2015-11-04 16:28:26 -05:00
$locale = get_locale ();
if ( 'ca' === $locale ) {
// " de abril| de agost| de octubre..." -> " d'abril| d'agost| d'octubre..."
$date = preg_replace ( '# de ([ao])#i' , " d' \\ 1 " , $date );
}
return $date ;
}
2008-06-15 05:38:32 -04:00
/**
2022-08-12 05:53:11 -04:00
* Converts float number to format based on the locale .
2008-06-15 05:38:32 -04:00
*
* @ since 2.3 . 0
*
2019-08-03 21:46:55 -04:00
* @ global WP_Locale $wp_locale WordPress date and time locale object .
2015-05-25 12:11:25 -04:00
*
2016-02-23 13:44:26 -05:00
* @ param float $number The number to convert based on locale .
* @ param int $decimals Optional . Precision of the number of decimal places . Default 0.
2008-06-15 05:38:32 -04:00
* @ return string Converted number in string format .
*/
2010-04-22 17:39:37 -04:00
function number_format_i18n ( $number , $decimals = 0 ) {
2007-04-24 20:49:57 -04:00
global $wp_locale ;
2015-10-12 20:30:24 -04:00
if ( isset ( $wp_locale ) ) {
$formatted = number_format ( $number , absint ( $decimals ), $wp_locale -> number_format [ 'decimal_point' ], $wp_locale -> number_format [ 'thousands_sep' ] );
} else {
$formatted = number_format ( $number , absint ( $decimals ) );
}
2014-04-13 20:20:14 -04:00
/**
2016-05-22 14:36:27 -04:00
* Filters the number formatted based on the locale .
2014-04-13 20:20:14 -04:00
*
2017-08-01 10:38:48 -04:00
* @ since 2.8 . 0
2018-02-09 11:55:31 -05:00
* @ since 4.9 . 0 The `$number` and `$decimals` parameters were added .
2014-04-13 20:20:14 -04:00
*
* @ param string $formatted Converted number in string format .
2017-08-01 10:38:48 -04:00
* @ param float $number The number to convert based on locale .
* @ param int $decimals Precision of the number of decimal places .
2014-04-13 20:20:14 -04:00
*/
2017-08-01 10:38:48 -04:00
return apply_filters ( 'number_format_i18n' , $formatted , $number , $decimals );
2007-04-24 20:49:57 -04:00
}
2008-06-15 05:38:32 -04:00
/**
2022-03-18 16:48:02 -04:00
* Converts a number of bytes to the largest unit the bytes will fit into .
2008-06-15 05:38:32 -04:00
*
2016-06-14 17:41:28 -04:00
* It is easier to read 1 KB than 1024 bytes and 1 MB than 1048576 bytes . Converts
2008-06-15 05:38:32 -04:00
* number of bytes to human readable number by taking the number of that unit
2022-03-18 16:48:02 -04:00
* that the bytes will go into it . Supports YB value .
2008-06-15 05:38:32 -04:00
*
* Please note that integers in PHP are limited to 32 bits , unless they are on
* 64 bit architecture , then they have 64 bit size . If you need to place the
* larger size then what PHP integer type will hold , then use a string . It will
* be converted to a double , which should always have 64 bit length .
*
* Technically the correct unit names for powers of 1024 are KiB , MiB etc .
*
* @ since 2.3 . 0
2022-03-18 16:48:02 -04:00
* @ since 6.0 . 0 Support for PB , EB , ZB , and YB was added .
2008-06-15 05:38:32 -04:00
*
2014-06-29 23:56:15 -04:00
* @ param int | string $bytes Number of bytes . Note max integer size for integers .
* @ param int $decimals Optional . Precision of number of decimal places . Default 0.
2020-06-16 17:24:07 -04:00
* @ return string | false Number string on success , false on failure .
2008-06-15 05:38:32 -04:00
*/
2010-04-22 17:39:37 -04:00
function size_format ( $bytes , $decimals = 0 ) {
2007-07-15 13:52:50 -04:00
$quant = array (
2022-03-18 16:48:02 -04:00
/* translators: Unit symbol for yottabyte. */
_x ( 'YB' , 'unit symbol' ) => YB_IN_BYTES ,
/* translators: Unit symbol for zettabyte. */
_x ( 'ZB' , 'unit symbol' ) => ZB_IN_BYTES ,
/* translators: Unit symbol for exabyte. */
_x ( 'EB' , 'unit symbol' ) => EB_IN_BYTES ,
/* translators: Unit symbol for petabyte. */
_x ( 'PB' , 'unit symbol' ) => PB_IN_BYTES ,
2020-06-16 02:10:08 -04:00
/* translators: Unit symbol for terabyte. */
_x ( 'TB' , 'unit symbol' ) => TB_IN_BYTES ,
/* translators: Unit symbol for gigabyte. */
_x ( 'GB' , 'unit symbol' ) => GB_IN_BYTES ,
/* translators: Unit symbol for megabyte. */
_x ( 'MB' , 'unit symbol' ) => MB_IN_BYTES ,
/* translators: Unit symbol for kilobyte. */
_x ( 'KB' , 'unit symbol' ) => KB_IN_BYTES ,
/* translators: Unit symbol for byte. */
_x ( 'B' , 'unit symbol' ) => 1 ,
2007-07-15 13:52:50 -04:00
);
2015-01-05 08:13:23 -05:00
2016-07-05 06:36:30 -04:00
if ( 0 === $bytes ) {
2020-06-16 02:10:08 -04:00
/* translators: Unit symbol for byte. */
return number_format_i18n ( 0 , $decimals ) . ' ' . _x ( 'B' , 'unit symbol' );
2016-07-05 06:36:30 -04:00
}
2015-01-05 08:13:23 -05:00
foreach ( $quant as $unit => $mag ) {
2020-10-18 13:27:06 -04:00
if ( ( float ) $bytes >= $mag ) {
2010-04-22 17:39:37 -04:00
return number_format_i18n ( $bytes / $mag , $decimals ) . ' ' . $unit ;
2015-01-05 08:13:23 -05:00
}
}
2008-01-27 23:55:54 -05:00
return false ;
2007-07-15 13:52:50 -04:00
}
2018-09-08 00:20:24 -04:00
/**
2022-08-12 05:53:11 -04:00
* Converts a duration to human readable format .
2018-09-08 00:20:24 -04:00
*
2019-01-08 14:56:48 -05:00
* @ since 5.1 . 0
2018-09-08 00:20:24 -04:00
*
2019-01-08 14:56:48 -05:00
* @ param string $duration Duration will be in string format ( HH : ii : ss ) OR ( ii : ss ),
* with a possible prepended negative sign ( - ) .
* @ return string | false A human readable duration string , false on failure .
2018-09-08 00:20:24 -04:00
*/
2019-01-08 14:56:48 -05:00
function human_readable_duration ( $duration = '' ) {
if ( ( empty ( $duration ) || ! is_string ( $duration ) ) ) {
2018-09-08 00:20:24 -04:00
return false ;
}
2019-01-08 14:56:48 -05:00
$duration = trim ( $duration );
// Remove prepended negative sign.
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 10:57:24 -04:00
if ( str_starts_with ( $duration , '-' ) ) {
2019-01-08 14:56:48 -05:00
$duration = substr ( $duration , 1 );
2018-09-08 00:20:24 -04:00
}
2019-01-08 14:56:48 -05:00
// Extract duration parts.
$duration_parts = array_reverse ( explode ( ':' , $duration ) );
$duration_count = count ( $duration_parts );
2018-09-08 00:20:24 -04:00
2019-01-08 14:56:48 -05:00
$hour = null ;
$minute = null ;
$second = null ;
2018-09-08 00:20:24 -04:00
if ( 3 === $duration_count ) {
2019-01-08 14:56:48 -05:00
// Validate HH:ii:ss duration format.
if ( ! ( ( bool ) preg_match ( '/^([0-9]+):([0-5]?[0-9]):([0-5]?[0-9])$/' , $duration ) ) ) {
return false ;
}
2018-09-08 00:20:24 -04:00
// Three parts: hours, minutes & seconds.
2019-01-08 14:56:48 -05:00
list ( $second , $minute , $hour ) = $duration_parts ;
2018-09-08 00:20:24 -04:00
} elseif ( 2 === $duration_count ) {
2019-01-08 14:56:48 -05:00
// Validate ii:ss duration format.
if ( ! ( ( bool ) preg_match ( '/^([0-5]?[0-9]):([0-5]?[0-9])$/' , $duration ) ) ) {
return false ;
}
2018-09-08 00:20:24 -04:00
// Two parts: minutes & seconds.
2019-01-08 14:56:48 -05:00
list ( $second , $minute ) = $duration_parts ;
2018-09-08 00:20:24 -04:00
} else {
return false ;
}
2019-01-08 14:56:48 -05:00
$human_readable_duration = array ();
2018-09-08 00:20:24 -04:00
// Add the hour part to the string.
2019-01-08 14:56:48 -05:00
if ( is_numeric ( $hour ) ) {
2019-09-02 20:41:05 -04:00
/* translators: %s: Time duration in hour or hours. */
2018-09-08 00:20:24 -04:00
$human_readable_duration [] = sprintf ( _n ( '%s hour' , '%s hours' , $hour ), ( int ) $hour );
}
// Add the minute part to the string.
2019-01-08 14:56:48 -05:00
if ( is_numeric ( $minute ) ) {
2019-09-02 20:41:05 -04:00
/* translators: %s: Time duration in minute or minutes. */
2018-09-08 00:20:24 -04:00
$human_readable_duration [] = sprintf ( _n ( '%s minute' , '%s minutes' , $minute ), ( int ) $minute );
}
// Add the second part to the string.
2019-01-08 14:56:48 -05:00
if ( is_numeric ( $second ) ) {
2019-09-02 20:41:05 -04:00
/* translators: %s: Time duration in second or seconds. */
2018-09-08 00:20:24 -04:00
$human_readable_duration [] = sprintf ( _n ( '%s second' , '%s seconds' , $second ), ( int ) $second );
}
return implode ( ', ' , $human_readable_duration );
}
2008-08-09 00:51:51 -04:00
/**
2022-08-12 05:53:11 -04:00
* Gets the week start and end from the datetime or date string from MySQL .
2008-08-09 00:51:51 -04:00
*
* @ since 0.71
*
2014-07-01 10:59:15 -04:00
* @ param string $mysqlstring Date or datetime field type from MySQL .
* @ param int | string $start_of_week Optional . Start of the week as an integer . Default empty string .
2021-10-30 16:17:01 -04:00
* @ return int [] {
* Week start and end dates as Unix timestamps .
*
* @ type int $start The week start date as a Unix timestamp .
* @ type int $end The week end date as a Unix timestamp .
* }
2008-08-09 00:51:51 -04:00
*/
2007-12-06 14:49:33 -05:00
function get_weekstartend ( $mysqlstring , $start_of_week = '' ) {
2014-07-01 10:59:15 -04:00
// MySQL string year.
2014-06-29 23:56:15 -04:00
$my = substr ( $mysqlstring , 0 , 4 );
2014-07-01 10:59:15 -04:00
// MySQL string month.
2014-06-29 23:56:15 -04:00
$mm = substr ( $mysqlstring , 8 , 2 );
2014-07-01 10:59:15 -04:00
// MySQL string day.
2014-06-29 23:56:15 -04:00
$md = substr ( $mysqlstring , 5 , 2 );
2014-07-01 10:59:15 -04:00
// The timestamp for MySQL string day.
2014-06-29 23:56:15 -04:00
$day = mktime ( 0 , 0 , 0 , $md , $mm , $my );
// The day of the week from the timestamp.
2019-05-25 20:12:54 -04:00
$weekday = gmdate ( 'w' , $day );
2014-06-29 23:56:15 -04:00
2017-11-30 18:11:00 -05:00
if ( ! is_numeric ( $start_of_week ) ) {
2007-12-06 14:49:33 -05:00
$start_of_week = get_option ( 'start_of_week' );
2017-11-30 18:11:00 -05:00
}
2005-04-10 16:07:46 -04:00
2017-11-30 18:11:00 -05:00
if ( $weekday < $start_of_week ) {
2010-05-07 01:01:29 -04:00
$weekday += 7 ;
2017-11-30 18:11:00 -05:00
}
2005-04-10 16:07:46 -04:00
2014-06-29 23:56:15 -04:00
// The most recent week start day on or before $day.
$start = $day - DAY_IN_SECONDS * ( $weekday - $start_of_week );
2015-11-06 11:37:27 -05:00
// $start + 1 week - 1 second.
$end = $start + WEEK_IN_SECONDS - 1 ;
2010-05-07 01:01:29 -04:00
return compact ( 'start' , 'end' );
2003-04-21 17:37:11 -04:00
}
2008-06-15 05:38:32 -04:00
/**
2022-08-12 05:53:11 -04:00
* Serializes data , if needed .
2020-03-13 17:07:06 -04:00
*
* @ since 2.0 . 5
*
* @ param string | array | object $data Data that might be serialized .
* @ return mixed A scalar data .
*/
function maybe_serialize ( $data ) {
if ( is_array ( $data ) || is_object ( $data ) ) {
return serialize ( $data );
}
/*
* Double serialization is required for backward compatibility .
* See https :// core . trac . wordpress . org / ticket / 12930
* Also the world will end . See WP 3.6 . 1.
*/
if ( is_serialized ( $data , false ) ) {
return serialize ( $data );
}
return $data ;
}
/**
2022-08-12 05:53:11 -04:00
* Unserializes data only if it was serialized .
2008-06-15 05:38:32 -04:00
*
* @ since 2.0 . 0
*
2020-03-13 17:07:06 -04:00
* @ param string $data Data that might be unserialized .
2008-06-15 05:38:32 -04:00
* @ return mixed Unserialized data can be any type .
*/
2020-03-13 17:07:06 -04:00
function maybe_unserialize ( $data ) {
if ( is_serialized ( $data ) ) { // Don't attempt to unserialize data that wasn't serialized going in.
2020-03-13 17:13:08 -04:00
return @ unserialize ( trim ( $data ) );
2017-11-30 18:11:00 -05:00
}
2020-03-13 17:07:06 -04:00
return $data ;
2006-10-12 19:54:36 -04:00
}
2008-06-15 05:38:32 -04:00
/**
2022-08-12 05:53:11 -04:00
* Checks value to find if it was serialized .
2008-06-15 05:38:32 -04:00
*
2022-08-12 05:26:12 -04:00
* If $data is not a string , then returned value will always be false .
2008-06-15 05:38:32 -04:00
* Serialized data is always a string .
*
* @ since 2.0 . 5
2022-08-12 05:26:12 -04:00
* @ since 6.1 . 0 Added Enum support .
2008-06-15 05:38:32 -04:00
*
2014-06-29 23:56:15 -04:00
* @ param string $data Value to check to see if was serialized .
* @ param bool $strict Optional . Whether to be strict about the end of the string . Default true .
2008-06-15 05:38:32 -04:00
* @ return bool False if not serialized and true if it was .
*/
2013-09-10 14:10:09 -04:00
function is_serialized ( $data , $strict = true ) {
2020-01-28 19:45:18 -05:00
// If it isn't a string, it isn't serialized.
2014-03-17 16:09:17 -04:00
if ( ! is_string ( $data ) ) {
2009-12-22 08:42:58 -05:00
return false ;
2014-03-17 16:09:17 -04:00
}
2009-12-22 08:42:58 -05:00
$data = trim ( $data );
2020-05-16 14:42:12 -04:00
if ( 'N;' === $data ) {
2009-12-22 08:42:58 -05:00
return true ;
2014-03-17 16:09:17 -04:00
}
if ( strlen ( $data ) < 4 ) {
2009-12-22 08:42:58 -05:00
return false ;
2014-03-17 16:09:17 -04:00
}
if ( ':' !== $data [ 1 ] ) {
2010-11-11 11:10:16 -05:00
return false ;
2014-03-17 16:09:17 -04:00
}
2013-09-10 14:10:09 -04:00
if ( $strict ) {
2014-03-17 16:09:17 -04:00
$lastc = substr ( $data , - 1 );
if ( ';' !== $lastc && '}' !== $lastc ) {
2013-09-10 14:10:09 -04:00
return false ;
2014-03-17 16:09:17 -04:00
}
2013-09-10 14:10:09 -04:00
} else {
2013-09-10 23:23:08 -04:00
$semicolon = strpos ( $data , ';' );
$brace = strpos ( $data , '}' );
// Either ; or } must exist.
2017-11-30 18:11:00 -05:00
if ( false === $semicolon && false === $brace ) {
2013-09-10 23:23:08 -04:00
return false ;
2017-11-30 18:11:00 -05:00
}
2013-09-10 23:23:08 -04:00
// But neither must be in the first X characters.
2017-11-30 18:11:00 -05:00
if ( false !== $semicolon && $semicolon < 3 ) {
2013-09-10 23:23:08 -04:00
return false ;
2017-11-30 18:11:00 -05:00
}
if ( false !== $brace && $brace < 4 ) {
2013-09-10 14:10:09 -04:00
return false ;
2017-11-30 18:11:00 -05:00
}
2013-09-10 14:10:09 -04:00
}
2010-11-11 11:10:16 -05:00
$token = $data [ 0 ];
switch ( $token ) {
2017-11-30 18:11:00 -05:00
case 's' :
2013-09-10 14:10:09 -04:00
if ( $strict ) {
2014-03-17 16:09:17 -04:00
if ( '"' !== substr ( $data , - 2 , 1 ) ) {
2013-09-10 14:10:09 -04:00
return false ;
2014-03-17 16:09:17 -04: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 10:36:26 -04:00
} elseif ( ! str_contains ( $data , '"' ) ) {
2010-11-11 11:10:16 -05:00
return false ;
2013-09-10 14:10:09 -04:00
}
2020-01-28 19:45:18 -05:00
// Or else fall through.
2017-11-30 18:11:00 -05:00
case 'a' :
case 'O' :
2022-08-12 05:26:12 -04:00
case 'E' :
2010-11-11 11:10:16 -05:00
return ( bool ) preg_match ( " /^ { $token } :[0-9]+:/s " , $data );
2017-11-30 18:11:00 -05:00
case 'b' :
case 'i' :
case 'd' :
2013-09-10 14:10:09 -04:00
$end = $strict ? '$' : '' ;
2019-08-05 09:55:57 -04:00
return ( bool ) preg_match ( " /^ { $token } :[0-9.E+-]+; $end / " , $data );
2009-12-22 08:42:58 -05:00
}
return false ;
2006-10-12 19:54:36 -04:00
}
2008-06-15 05:38:32 -04:00
/**
2022-08-12 05:53:11 -04:00
* Checks whether serialized data is of string type .
2008-06-15 05:38:32 -04:00
*
* @ since 2.0 . 5
*
2014-06-29 23:56:15 -04:00
* @ param string $data Serialized data .
2008-06-15 05:38:32 -04:00
* @ return bool False if not a serialized string , true if it is .
*/
2007-10-11 01:46:57 -04:00
function is_serialized_string ( $data ) {
2014-06-29 23:56:15 -04:00
// if it isn't a string, it isn't a serialized string.
2014-03-17 16:09:17 -04:00
if ( ! is_string ( $data ) ) {
2006-10-12 19:54:36 -04:00
return false ;
2014-03-17 16:09:17 -04:00
}
2007-10-11 01:46:57 -04:00
$data = trim ( $data );
2014-03-17 16:09:17 -04:00
if ( strlen ( $data ) < 4 ) {
2011-04-30 00:41:56 -04:00
return false ;
2014-03-17 16:09:17 -04:00
} elseif ( ':' !== $data [ 1 ] ) {
2011-04-30 00:41:56 -04:00
return 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 10:57:24 -04:00
} elseif ( ! str_ends_with ( $data , ';' ) ) {
2011-04-30 00:41:56 -04:00
return false ;
2020-02-09 11:55:09 -05:00
} elseif ( 's' !== $data [ 0 ] ) {
2011-04-30 00:41:56 -04:00
return false ;
2014-03-17 16:09:17 -04:00
} elseif ( '"' !== substr ( $data , - 2 , 1 ) ) {
2011-04-30 00:41:56 -04:00
return false ;
2014-03-17 16:09:17 -04:00
} else {
2006-10-12 19:54:36 -04:00
return true ;
2014-03-17 16:09:17 -04:00
}
2005-11-29 02:58:50 -05:00
}
2008-08-09 00:51:51 -04:00
/**
2022-08-12 05:53:11 -04:00
* Retrieves post title from XMLRPC XML .
2008-08-09 00:51:51 -04:00
*
* If the title element is not part of the XML , then the default post title from
* the $post_default_title will be used instead .
*
2008-08-10 12:45:50 -04:00
* @ since 0.71
2008-08-09 00:51:51 -04:00
*
2014-06-29 23:56:15 -04:00
* @ global string $post_default_title Default XML - RPC post title .
2008-08-09 00:51:51 -04:00
*
* @ param string $content XMLRPC XML Request content
* @ return string Post title
*/
2007-10-11 01:46:57 -04:00
function xmlrpc_getposttitle ( $content ) {
2003-04-21 17:37:11 -04:00
global $post_default_title ;
2007-10-11 01:46:57 -04:00
if ( preg_match ( '/<title>(.+?)<\/title>/is' , $content , $matchtitle ) ) {
2009-04-20 18:15:14 -04:00
$post_title = $matchtitle [ 1 ];
2003-04-21 17:37:11 -04:00
} else {
$post_title = $post_default_title ;
}
2003-06-07 13:19:38 -04:00
return $post_title ;
2003-04-21 17:37:11 -04:00
}
2005-10-10 05:25:38 -04:00
2008-08-09 00:51:51 -04:00
/**
2022-08-12 05:53:11 -04:00
* Retrieves the post category or categories from XMLRPC XML .
2008-08-09 00:51:51 -04:00
*
* If the category element is not found , then the default post category will be
* used . The return type then would be what $post_default_category . If the
* category is found , then it will always be an array .
*
2008-08-10 12:45:50 -04:00
* @ since 0.71
2008-08-09 00:51:51 -04:00
*
2014-06-29 23:56:15 -04:00
* @ global string $post_default_category Default XML - RPC post category .
2008-08-09 00:51:51 -04:00
*
* @ param string $content XMLRPC XML Request content
* @ return string | array List of categories or category name .
*/
2007-10-11 01:46:57 -04:00
function xmlrpc_getpostcategory ( $content ) {
2003-04-21 17:37:11 -04:00
global $post_default_category ;
2007-10-11 01:46:57 -04:00
if ( preg_match ( '/<category>(.+?)<\/category>/is' , $content , $matchcat ) ) {
$post_category = trim ( $matchcat [ 1 ], ',' );
$post_category = explode ( ',' , $post_category );
2003-04-21 17:37:11 -04:00
} else {
$post_category = $post_default_category ;
}
2003-06-07 13:19:38 -04:00
return $post_category ;
2003-04-21 17:37:11 -04:00
}
2008-08-09 00:51:51 -04:00
/**
* XMLRPC XML content without title and category elements .
*
2008-08-10 12:45:50 -04:00
* @ since 0.71
2008-08-09 00:51:51 -04:00
*
2014-06-29 23:56:15 -04:00
* @ param string $content XML - RPC XML Request content .
2008-08-09 00:51:51 -04:00
* @ return string XMLRPC XML Request content without title and category elements .
*/
2007-10-11 01:46:57 -04:00
function xmlrpc_removepostdata ( $content ) {
$content = preg_replace ( '/<title>(.+?)<\/title>/si' , '' , $content );
$content = preg_replace ( '/<category>(.+?)<\/category>/si' , '' , $content );
$content = trim ( $content );
2003-06-07 13:19:38 -04:00
return $content ;
2003-04-21 17:37:11 -04:00
}
2013-09-09 23:18:08 -04:00
/**
2022-08-12 05:53:11 -04:00
* Uses RegEx to extract URLs from arbitrary content .
2013-09-09 23:18:08 -04:00
*
* @ since 3.7 . 0
2022-03-31 23:40:02 -04:00
* @ since 6.0 . 0 Fixes support for HTML entities ( Trac 30580 ) .
2013-09-09 23:18:08 -04:00
*
2014-06-29 23:56:15 -04:00
* @ param string $content Content to extract URLs from .
2019-11-05 16:23:02 -05:00
* @ return string [] Array of URLs found in passed string .
2013-09-09 23:18:08 -04:00
*/
function wp_extract_urls ( $content ) {
preg_match_all (
2014-09-22 22:50:19 -04:00
" #([ \" ']?)( "
2017-11-30 18:11:00 -05:00
. '(?:([\w-]+:)?//?)'
. '[^\s()<>]+'
. '[.]'
. '(?:'
. '\([\w\d]+\)|'
. '(?:'
2022-03-31 23:40:02 -04:00
. " [^`!() \ [ \ ] { }:' \" .,<>«»“”‘’ \ s]| "
2017-11-30 18:11:00 -05:00
. '(?:[:]\d+)?/?'
. ')+'
. ')'
2014-09-22 22:50:19 -04:00
. " ) \\ 1# " ,
2013-09-09 23:18:08 -04:00
$content ,
$post_links
);
2022-03-31 23:40:02 -04:00
$post_links = array_unique (
array_map (
static function ( $link ) {
// Decode to replace valid entities, like &.
$link = html_entity_decode ( $link );
// Maintain backward compatibility by removing extraneous semi-colons (`;`).
return str_replace ( ';' , '' , $link );
},
$post_links [ 2 ]
)
);
2013-09-09 23:18:08 -04:00
return array_values ( $post_links );
}
2008-08-10 12:45:50 -04:00
/**
2022-08-12 05:53:11 -04:00
* Checks content for video and audio links to add as enclosures .
2008-08-10 12:45:50 -04:00
*
2009-05-13 01:15:27 -04:00
* Will not add enclosures that have already been added and will
* remove enclosures that are no longer in the post . This is called as
2008-08-10 16:31:49 -04:00
* pingbacks and trackbacks .
2008-08-10 12:45:50 -04:00
*
* @ since 1.5 . 0
2019-09-18 21:49:56 -04:00
* @ since 5.3 . 0 The `$content` parameter was made optional , and the `$post` parameter was
* updated to accept a post ID or a WP_Post object .
2020-08-15 09:40:03 -04:00
* @ since 5.6 . 0 The `$content` parameter is no longer optional , but passing `null` to skip it
* is still supported .
2008-08-10 12:45:50 -04:00
*
2015-10-14 19:44:25 -04:00
* @ global wpdb $wpdb WordPress database abstraction object .
2008-08-10 12:45:50 -04:00
*
2020-08-15 09:40:03 -04:00
* @ param string | null $content Post content . If `null` , the `post_content` field from `$post` is used .
2020-07-23 17:11:05 -04:00
* @ param int | WP_Post $post Post ID or post object .
2021-01-05 11:48:07 -05:00
* @ return void | false Void on success , false if the post is not found .
2008-08-10 12:45:50 -04:00
*/
2020-08-15 09:40:03 -04:00
function do_enclose ( $content , $post ) {
2007-12-06 14:49:33 -05:00
global $wpdb ;
2010-11-17 13:47:34 -05:00
2019-09-18 21:54:56 -04:00
// @todo Tidy this code and make the debug code optional.
Coding Standards: Replace `include_once` with `require_once` for required files.
Per [https://developer.wordpress.org/coding-standards/wordpress-coding-standards/php/#writing-include-require-statements WordPress PHP coding standards], it is ''strongly recommended'' to use `require[_once]` for unconditional includes. When using `include[_once]`, PHP will throw a warning when the file is not found but will continue execution, which will almost certainly lead to other errors/warnings/notices being thrown if your application depends on the file loaded, potentially leading to security leaks. For that reason, `require[_once]` is generally the better choice as it will throw a `Fatal Error` if the file cannot be found.
Follow-up to [1674], [1812], [1964], [6779], [8540], [10521], [11005], [11911], [16065], [16149], [25421], [25466], [25823], [37714], [42981], [45448], [47198], [54276], [55633].
Props kausaralm, SergeyBiryukov.
See #57839.
Built from https://develop.svn.wordpress.org/trunk@55641
git-svn-id: http://core.svn.wordpress.org/trunk@55153 1a063a9b-81f0-0310-95a4-ce76da25c4cd
2023-04-09 07:57:22 -04:00
require_once ABSPATH . WPINC . '/class-IXR.php' ;
2016-08-31 12:31:29 -04:00
2019-09-18 21:49:56 -04:00
$post = get_post ( $post );
if ( ! $post ) {
return false ;
}
if ( null === $content ) {
$content = $post -> post_content ;
}
2004-10-18 08:09:20 -04:00
$post_links = array ();
2019-09-18 21:49:56 -04:00
$pung = get_enclosed ( $post -> ID );
2004-10-18 08:09:20 -04:00
2013-09-09 23:18:08 -04:00
$post_links_temp = wp_extract_urls ( $content );
2004-10-18 08:09:20 -04:00
2009-05-13 01:15:27 -04:00
foreach ( $pung as $link_test ) {
2019-09-18 21:54:56 -04:00
// Link is no longer in post.
if ( ! in_array ( $link_test , $post_links_temp , true ) ) {
2019-09-18 21:49:56 -04:00
$mids = $wpdb -> get_col ( $wpdb -> prepare ( " SELECT meta_id FROM $wpdb->postmeta WHERE post_id = %d AND meta_key = 'enclosure' AND meta_value LIKE %s " , $post -> ID , $wpdb -> esc_like ( $link_test ) . '%' ) );
2017-11-30 18:11:00 -05:00
foreach ( $mids as $mid ) {
2012-04-11 16:02:39 -04:00
delete_metadata_by_mid ( 'post' , $mid );
2017-11-30 18:11:00 -05:00
}
2009-05-13 01:15:27 -04:00
}
}
2013-09-09 23:18:08 -04:00
foreach ( ( array ) $post_links_temp as $link_test ) {
2019-09-18 21:54:56 -04:00
// If we haven't pung it already.
if ( ! in_array ( $link_test , $pung , true ) ) {
2020-04-24 03:28:10 -04:00
$test = parse_url ( $link_test );
2017-11-30 18:11:00 -05:00
if ( false === $test ) {
2010-04-16 15:48:30 -04:00
continue ;
2017-11-30 18:11:00 -05:00
}
if ( isset ( $test [ 'query' ] ) ) {
2004-10-18 08:09:20 -04:00
$post_links [] = $link_test ;
2019-09-18 21:54:56 -04:00
} elseif ( isset ( $test [ 'path' ] ) && ( '/' !== $test [ 'path' ] ) && ( '' !== $test [ 'path' ] ) ) {
2004-10-18 08:09:20 -04:00
$post_links [] = $link_test ;
2017-11-30 18:11:00 -05:00
}
2007-10-11 01:46:57 -04:00
}
}
2004-10-18 08:09:20 -04:00
2015-10-20 03:09:25 -04:00
/**
2016-05-22 14:36:27 -04:00
* Filters the list of enclosure links before querying the database .
2015-10-20 03:09:25 -04:00
*
* Allows for the addition and / or removal of potential enclosures to save
* to postmeta before checking the database for existing enclosures .
*
* @ since 4.4 . 0
*
2019-10-26 17:09:04 -04:00
* @ param string [] $post_links An array of enclosure links .
Docs: Update various DocBlocks and inline comments per the documentation standards.
Includes minor formatting edits for consistency.
Follow-up to [53/tests], [12179], [12946], [35288], [37884], [38810], [38928], [46596], [48131], [52955], [53548], [53813], [53873], [54118], [54316], [54420], [54421], [54803].
See #56792.
Built from https://develop.svn.wordpress.org/trunk@54855
git-svn-id: http://core.svn.wordpress.org/trunk@54407 1a063a9b-81f0-0310-95a4-ce76da25c4cd
2022-11-17 13:15:19 -05:00
* @ param int $post_id Post ID .
2015-10-20 03:09:25 -04:00
*/
2019-09-18 21:49:56 -04:00
$post_links = apply_filters ( 'enclosure_links' , $post_links , $post -> ID );
2015-10-20 03:09:25 -04:00
2008-08-06 16:31:54 -04:00
foreach ( ( array ) $post_links as $url ) {
2020-11-09 15:28:07 -05:00
$url = strip_fragment_from_url ( $url );
2019-09-18 21:54:56 -04:00
if ( '' !== $url && ! $wpdb -> get_var ( $wpdb -> prepare ( " SELECT post_id FROM $wpdb->postmeta WHERE post_id = %d AND meta_key = 'enclosure' AND meta_value LIKE %s " , $post -> ID , $wpdb -> esc_like ( $url ) . '%' ) ) ) {
2009-12-30 02:36:17 -05:00
2019-07-02 19:42:58 -04:00
$headers = wp_get_http_headers ( $url );
if ( $headers ) {
2023-02-03 08:35:20 -05:00
$len = isset ( $headers [ 'Content-Length' ] ) ? ( int ) $headers [ 'Content-Length' ] : 0 ;
$type = isset ( $headers [ 'Content-Type' ] ) ? $headers [ 'Content-Type' ] : '' ;
2005-03-07 03:56:47 -05:00
$allowed_types = array ( 'video' , 'audio' );
2009-12-30 02:36:17 -05:00
2020-01-28 19:45:18 -05:00
// Check to see if we can figure out the mime type from the extension.
2020-04-24 03:28:10 -04:00
$url_parts = parse_url ( $url );
2020-07-26 10:08:05 -04:00
if ( false !== $url_parts && ! empty ( $url_parts [ 'path' ] ) ) {
2010-04-16 15:48:30 -04:00
$extension = pathinfo ( $url_parts [ 'path' ], PATHINFO_EXTENSION );
2017-11-30 18:11:00 -05:00
if ( ! empty ( $extension ) ) {
2012-08-17 13:25:19 -04:00
foreach ( wp_get_mime_types () as $exts => $mime ) {
2010-04-16 15:48:30 -04:00
if ( preg_match ( '!^(' . $exts . ')$!i' , $extension ) ) {
$type = $mime ;
break ;
}
2009-12-30 02:36:17 -05:00
}
}
}
2019-09-18 21:54:56 -04:00
if ( in_array ( substr ( $type , 0 , strpos ( $type , '/' ) ), $allowed_types , true ) ) {
2019-09-18 21:49:56 -04:00
add_post_meta ( $post -> ID , 'enclosure' , " $url\n $len\n $mime\n " );
2005-03-07 03:56:47 -05:00
}
}
}
2007-10-11 01:46:57 -04:00
}
2005-03-07 03:56:47 -05:00
}
2008-06-15 05:38:32 -04:00
/**
2022-08-12 05:53:11 -04:00
* Retrieves HTTP Headers from URL .
2008-06-15 05:38:32 -04:00
*
* @ since 1.5 . 1
*
2014-06-29 23:56:15 -04:00
* @ param string $url URL to retrieve HTTP headers from .
* @ param bool $deprecated Not Used .
External Libraries: Update Requests library to version 2.0.0.
This is a major release and contains breaking changes.
Most important changes to be aware of for this release:
* All code is now namespaced. Though there is a full backward compatibility layer available and the old class names are still supported, using them will generate a deprecation notice (which can be silenced by plugins if they'd need to support multiple WP versions). See the [https://requests.ryanmccue.info/docs/upgrading.html upgrade guide] for more details.
* A lot of classes have been marked `final`. This should generally not affect userland code as care has been taken to not apply the `final` keyword to classes which are known to be extended in userland code.
* Extensive input validation has been added to Requests. When Requests is used as documented though, this will be unnoticable.
* A new `WpOrg\Requests\Requests::has_capabilities()` method has been introduced which can be used to address #37708.
* A new `WpOrg\Requests\Response::decode_body()` method has been introduced which may be usable to simplify some of the WP native wrapper code.
* Remaining PHP 8.0 compatibility fixed (support for named parameters).
* PHP 8.1 compatibility.
Release notes: https://github.com/WordPress/Requests/releases/tag/v2.0.0
For a full list of changes in this update, see the Requests GitHub:
https://github.com/WordPress/Requests/compare/v1.8.1...v2.0.0
This commit also resolves 2 blocking issues which previously caused the revert of [52244]:
* New Requests files are loaded into `wp-includes/Requests/src/`, matching the location of the library. In doing so, filesystems that are case-insensitive are not impacted (see #54582).
* Preload: During a Core update, the old Requests files are preloaded into memory before the update deletes the files. Preloading avoids fatal errors noted in #54562.
Follow-up to [50842], [51078], [52244], [52315], [52327], [52328].
Props jrf, schlessera, datagutten, wojsmol, dustinrue, soulseekah, szepeviktor. costdev, sergeybiryukov, peterwilsoncc, ironprogrammer, antonvlasenko, hellofromTonya, swissspidy, dd32, azaozz, TobiasBg, audrasjb.
Fixes #54504.
See #54582, #54562.
Built from https://develop.svn.wordpress.org/trunk@54997
git-svn-id: http://core.svn.wordpress.org/trunk@54530 1a063a9b-81f0-0310-95a4-ce76da25c4cd
2022-12-15 16:32:17 -05:00
* @ return \WpOrg\Requests\Utility\CaseInsensitiveDictionary | false Headers on success , false on failure .
2008-06-15 05:38:32 -04:00
*/
2008-09-27 17:41:19 -04:00
function wp_get_http_headers ( $url , $deprecated = false ) {
2017-11-30 18:11:00 -05:00
if ( ! empty ( $deprecated ) ) {
2016-07-06 08:40:29 -04:00
_deprecated_argument ( __FUNCTION__ , '2.7.0' );
2017-11-30 18:11:00 -05:00
}
2009-12-30 11:23:39 -05:00
2013-07-31 02:52:13 -04:00
$response = wp_safe_remote_head ( $url );
2008-10-01 20:32:21 -04:00
2017-11-30 18:11:00 -05:00
if ( is_wp_error ( $response ) ) {
2008-10-01 20:32:21 -04:00
return false ;
2017-11-30 18:11:00 -05:00
}
2008-10-01 20:32:21 -04:00
2008-09-27 17:41:19 -04:00
return wp_remote_retrieve_headers ( $response );
2007-12-16 16:34:48 -05:00
}
2008-06-15 05:38:32 -04:00
/**
2018-02-13 11:54:31 -05:00
* Determines whether the publish date of the current post in the loop is different
* from the publish date of the previous post in the loop .
2018-02-18 21:13:32 -05:00
*
2018-02-13 11:54:31 -05:00
* For more information on this and similar theme functions , check out
2018-02-18 21:13:32 -05:00
* the { @ link https :// developer . wordpress . org / themes / basics / conditional - tags /
2018-02-13 11:54:31 -05:00
* Conditional Tags } article in the Theme Developer Handbook .
2018-02-18 21:13:32 -05:00
*
2008-06-15 05:38:32 -04:00
* @ since 0.71
2014-06-29 23:56:15 -04:00
*
2014-06-30 21:44:15 -04:00
* @ global string $currentday The day of the current post in the loop .
2014-05-27 07:41:14 -04:00
* @ global string $previousday The day of the previous post in the loop .
2008-06-15 05:38:32 -04:00
*
2014-11-30 18:24:25 -05:00
* @ return int 1 when new day , 0 if not a new day .
2008-06-15 05:38:32 -04:00
*/
2003-10-27 02:00:42 -05:00
function is_new_day () {
2010-11-11 11:22:18 -05:00
global $currentday , $previousday ;
2019-05-22 13:53:52 -04:00
if ( $currentday !== $previousday ) {
2007-10-11 01:46:57 -04:00
return 1 ;
2017-11-30 18:11:00 -05:00
} else {
2007-10-11 01:46:57 -04:00
return 0 ;
2017-11-30 18:11:00 -05:00
}
2003-10-27 02:00:42 -05:00
}
2008-06-29 23:23:44 -04:00
/**
2022-08-12 05:53:11 -04:00
* Builds URL query based on an associative and , or indexed array .
2008-06-29 23:23:44 -04:00
*
* This is a convenient function for easily building url queries . It sets the
* separator to '&' and uses _http_build_query () function .
*
2014-06-30 21:44:15 -04:00
* @ since 2.3 . 0
*
2008-06-29 23:23:44 -04:00
* @ see _http_build_query () Used to build the query
2020-01-19 22:14:06 -05:00
* @ link https :// www . php . net / manual / en / function . http - build - query . php for more on what
2017-11-30 18:11:00 -05:00
* http_build_query () does .
2008-06-29 23:23:44 -04:00
*
* @ param array $data URL - encode key / value pairs .
2014-06-30 21:44:15 -04:00
* @ return string URL - encoded string .
2008-06-29 23:23:44 -04:00
*/
2007-10-11 01:46:57 -04:00
function build_query ( $data ) {
2008-08-09 00:51:51 -04:00
return _http_build_query ( $data , null , '&' , '' , false );
2007-09-08 10:27:24 -04:00
}
2014-06-29 23:47:16 -04:00
/**
* From php . net ( modified by Mark Jaquith to behave like the native PHP5 function ) .
*
* @ since 3.2 . 0
2014-07-07 02:19:14 -04:00
* @ access private
2014-06-29 23:47:16 -04:00
*
2020-01-19 22:14:06 -05:00
* @ see https :// www . php . net / manual / en / function . http - build - query . php
2014-06-29 23:47:16 -04:00
*
2020-06-20 08:02:12 -04:00
* @ param array | object $data An array or object of data . Converted to array .
* @ param string $prefix Optional . Numeric index . If set , start parameter numbering with it .
* Default null .
* @ param string $sep Optional . Argument separator ; defaults to 'arg_separator.output' .
* Default null .
2023-02-21 11:39:19 -05:00
* @ param string $key Optional . Used to prefix key name . Default empty string .
2020-06-20 08:02:12 -04:00
* @ param bool $urlencode Optional . Whether to use urlencode () in the result . Default true .
2014-06-29 23:47:16 -04:00
* @ return string The query string .
*/
function _http_build_query ( $data , $prefix = null , $sep = null , $key = '' , $urlencode = true ) {
2011-04-05 13:13:04 -04:00
$ret = array ();
foreach ( ( array ) $data as $k => $v ) {
2017-11-30 18:11:00 -05:00
if ( $urlencode ) {
$k = urlencode ( $k );
}
2020-02-09 11:55:09 -05:00
if ( is_int ( $k ) && null != $prefix ) {
2017-11-30 18:11:00 -05:00
$k = $prefix . $k ;
}
if ( ! empty ( $key ) ) {
2011-04-05 13:13:04 -04:00
$k = $key . '%5B' . $k . '%5D' ;
2017-11-30 18:11:00 -05:00
}
2020-02-09 11:55:09 -05:00
if ( null === $v ) {
2011-04-05 13:13:04 -04:00
continue ;
2020-02-09 11:55:09 -05:00
} elseif ( false === $v ) {
2011-04-05 13:13:04 -04:00
$v = '0' ;
2017-11-30 18:11:00 -05:00
}
2011-04-05 13:13:04 -04:00
2017-11-30 18:11:00 -05:00
if ( is_array ( $v ) || is_object ( $v ) ) {
array_push ( $ret , _http_build_query ( $v , '' , $sep , $k , $urlencode ) );
} elseif ( $urlencode ) {
array_push ( $ret , $k . '=' . urlencode ( $v ) );
} else {
array_push ( $ret , $k . '=' . $v );
}
2011-04-05 13:13:04 -04:00
}
2017-11-30 18:11:00 -05:00
if ( null === $sep ) {
$sep = ini_get ( 'arg_separator.output' );
}
2011-04-05 13:13:04 -04:00
2017-11-30 18:11:00 -05:00
return implode ( $sep , $ret );
2011-04-05 13:13:04 -04:00
}
2008-06-15 05:38:32 -04:00
/**
2015-09-24 15:32:24 -04:00
* Retrieves a modified URL query string .
2008-06-15 05:38:32 -04:00
*
2015-09-24 15:32:24 -04:00
* You can rebuild the URL and append query variables to the URL query by using this function .
* There are two ways to use this function ; either a single key and value , or an associative array .
2008-06-15 05:38:32 -04:00
*
2015-09-24 15:32:24 -04:00
* Using a single key and value :
2008-06-15 05:38:32 -04:00
*
2015-09-24 15:32:24 -04:00
* add_query_arg ( 'key' , 'value' , 'http://example.com' );
*
* Using an associative array :
2015-10-05 23:19:25 -04:00
*
2015-09-24 15:32:24 -04:00
* add_query_arg ( array (
* 'key1' => 'value1' ,
* 'key2' => 'value2' ,
* ), 'http://example.com' );
2015-10-05 23:19:25 -04:00
*
2015-09-24 15:32:24 -04:00
* Omitting the URL from either use results in the current URL being used
* ( the value of `$_SERVER['REQUEST_URI']` ) .
2015-10-05 23:19:25 -04:00
*
2015-09-24 15:32:24 -04:00
* Values are expected to be encoded appropriately with urlencode () or rawurlencode () .
*
* Setting any query variable ' s value to boolean false removes the key ( see remove_query_arg ()) .
*
* Important : The return value of add_query_arg () is not escaped by default . Output should be
* late - escaped with esc_url () or similar to help prevent vulnerability to cross - site scripting
* ( XSS ) attacks .
2015-09-17 05:39:24 -04:00
*
2008-06-15 05:38:32 -04:00
* @ since 1.5 . 0
2019-10-09 00:28:02 -04:00
* @ since 5.3 . 0 Formalized the existing and already documented parameters
* by adding `...$args` to the function signature .
2008-06-15 05:38:32 -04:00
*
2015-09-24 15:32:24 -04:00
* @ param string | array $key Either a query variable key , or an associative array of query variables .
* @ param string $value Optional . Either a query variable value , or a URL to act upon .
* @ param string $url Optional . A URL to act upon .
* @ return string New URL query string ( unescaped ) .
2008-06-15 05:38:32 -04:00
*/
2019-09-15 06:45:56 -04:00
function add_query_arg ( ... $args ) {
2012-07-31 11:28:10 -04:00
if ( is_array ( $args [ 0 ] ) ) {
2017-11-30 18:11:00 -05:00
if ( count ( $args ) < 2 || false === $args [ 1 ] ) {
2006-01-23 18:42:25 -05:00
$uri = $_SERVER [ 'REQUEST_URI' ];
2017-11-30 18:11:00 -05:00
} else {
2012-07-31 11:28:10 -04:00
$uri = $args [ 1 ];
2017-11-30 18:11:00 -05:00
}
2005-10-10 05:25:38 -04:00
} else {
2017-11-30 18:11:00 -05:00
if ( count ( $args ) < 3 || false === $args [ 2 ] ) {
2004-11-21 01:03:19 -05:00
$uri = $_SERVER [ 'REQUEST_URI' ];
2017-11-30 18:11:00 -05:00
} else {
2012-07-31 11:28:10 -04:00
$uri = $args [ 2 ];
2017-11-30 18:11:00 -05:00
}
2004-10-20 17:28:37 -04:00
}
2004-11-21 01:03:19 -05:00
2019-07-02 19:42:58 -04:00
$frag = strstr ( $uri , '#' );
if ( $frag ) {
2007-10-11 01:46:57 -04:00
$uri = substr ( $uri , 0 , - strlen ( $frag ) );
2017-11-30 18:11:00 -05:00
} else {
2006-08-29 21:02:45 -04:00
$frag = '' ;
2017-11-30 18:11:00 -05:00
}
2006-08-29 21:02:45 -04:00
2013-06-19 04:33:10 -04:00
if ( 0 === stripos ( $uri , 'http://' ) ) {
2012-09-16 12:16:26 -04:00
$protocol = 'http://' ;
2017-11-30 18:11:00 -05:00
$uri = substr ( $uri , 7 );
2013-06-19 04:33:10 -04:00
} elseif ( 0 === stripos ( $uri , 'https://' ) ) {
2012-09-16 12:16:26 -04:00
$protocol = 'https://' ;
2017-11-30 18:11:00 -05:00
$uri = substr ( $uri , 8 );
2006-06-08 14:36:05 -04:00
} else {
$protocol = '' ;
}
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 10:36:26 -04:00
if ( str_contains ( $uri , '?' ) ) {
2013-09-10 19:38:09 -04:00
list ( $base , $query ) = explode ( '?' , $uri , 2 );
2017-11-30 18:11:00 -05:00
$base .= '?' ;
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 10:36:26 -04:00
} elseif ( $protocol || ! str_contains ( $uri , '=' ) ) {
2017-11-30 18:11:00 -05:00
$base = $uri . '?' ;
2004-10-20 17:28:37 -04:00
$query = '' ;
2005-04-01 00:42:46 -05:00
} else {
2017-11-30 18:11:00 -05:00
$base = '' ;
2005-04-01 00:42:46 -05:00
$query = $uri ;
2004-10-20 17:28:37 -04:00
}
2005-04-01 00:42:46 -05:00
2007-10-11 01:46:57 -04:00
wp_parse_str ( $query , $qs );
2020-01-28 19:45:18 -05:00
$qs = urlencode_deep ( $qs ); // This re-URL-encodes things that were already in the query string.
2012-07-31 11:28:10 -04:00
if ( is_array ( $args [ 0 ] ) ) {
2015-04-01 15:40:26 -04:00
foreach ( $args [ 0 ] as $k => $v ) {
$qs [ $k ] = $v ;
}
2005-10-10 05:25:38 -04:00
} else {
2012-07-31 11:28:10 -04:00
$qs [ $args [ 0 ] ] = $args [ 1 ];
2004-10-20 17:28:37 -04:00
}
2005-10-10 05:25:38 -04:00
2012-09-16 12:16:26 -04:00
foreach ( $qs as $k => $v ) {
2020-02-09 11:55:09 -05:00
if ( false === $v ) {
2017-11-30 18:11:00 -05:00
unset ( $qs [ $k ] );
}
2005-10-10 05:25:38 -04:00
}
2007-08-31 23:41:50 -04:00
2007-10-11 01:46:57 -04:00
$ret = build_query ( $qs );
$ret = trim ( $ret , '?' );
$ret = preg_replace ( '#=(&|$)#' , '$1' , $ret );
2006-08-29 21:02:45 -04:00
$ret = $protocol . $base . $ret . $frag ;
2007-10-11 01:46:57 -04:00
$ret = rtrim ( $ret , '?' );
2021-11-16 13:50:00 -05:00
$ret = str_replace ( '?#' , '#' , $ret );
2007-04-06 00:21:21 -04:00
return $ret ;
2004-10-20 17:28:37 -04:00
}
2008-06-15 05:38:32 -04:00
/**
2015-09-24 15:34:24 -04:00
* Removes an item or items from a query string .
2008-06-15 05:38:32 -04:00
*
2023-03-08 17:19:23 -05:00
* Important : The return value of remove_query_arg () is not escaped by default . Output should be
* late - escaped with esc_url () or similar to help prevent vulnerability to cross - site scripting
* ( XSS ) attacks .
*
2008-06-15 05:38:32 -04:00
* @ since 1.5 . 0
*
2020-11-24 16:27:05 -05:00
* @ param string | string [] $key Query key or keys to remove .
* @ param false | string $query Optional . When false uses the current URL . Default false .
2008-08-09 00:51:51 -04:00
* @ return string New URL query string .
2008-06-15 05:38:32 -04:00
*/
2014-06-30 21:44:15 -04:00
function remove_query_arg ( $key , $query = false ) {
2020-01-28 19:45:18 -05:00
if ( is_array ( $key ) ) { // Removing multiple keys.
2017-11-30 18:11:00 -05:00
foreach ( $key as $k ) {
2008-06-15 05:38:32 -04:00
$query = add_query_arg ( $k , false , $query );
2017-11-30 18:11:00 -05:00
}
2006-06-08 14:36:05 -04:00
return $query ;
}
2008-06-15 05:38:32 -04:00
return add_query_arg ( $key , false , $query );
2004-10-20 17:28:37 -04:00
}
2004-12-03 19:12:08 -05:00
2015-09-02 07:29:23 -04:00
/**
* Returns an array of single - use query variable names that can be removed from a URL .
*
* @ since 4.4 . 0
*
2020-12-10 18:59:03 -05:00
* @ return string [] An array of query variable names to remove from the URL .
2015-09-02 07:29:23 -04:00
*/
function wp_removable_query_args () {
$removable_query_args = array (
'activate' ,
'activated' ,
2020-07-06 23:59:02 -04:00
'admin_email_remind_later' ,
2015-09-02 07:29:23 -04:00
'approved' ,
2020-11-17 15:28:04 -05:00
'core-major-auto-updates-saved' ,
2015-09-02 07:29:23 -04:00
'deactivate' ,
2020-07-05 09:57:03 -04:00
'delete_count' ,
2015-09-02 07:29:23 -04:00
'deleted' ,
'disabled' ,
2019-12-21 11:14:04 -05:00
'doing_wp_cron' ,
2015-09-02 07:29:23 -04:00
'enabled' ,
'error' ,
2016-06-08 21:56:27 -04:00
'hotkeys_highlight_first' ,
'hotkeys_highlight_last' ,
2020-10-11 09:39:07 -04:00
'ids' ,
2015-09-02 07:29:23 -04:00
'locked' ,
'message' ,
'same' ,
'saved' ,
'settings-updated' ,
'skipped' ,
'spammed' ,
'trashed' ,
'unspammed' ,
'untrashed' ,
'update' ,
'updated' ,
2015-10-30 14:06:34 -04:00
'wp-post-new-reload' ,
2015-09-02 07:29:23 -04:00
);
/**
2020-12-10 18:59:03 -05:00
* Filters the list of query variable names to remove .
2015-09-02 07:29:23 -04:00
*
* @ since 4.2 . 0
*
2020-12-10 18:59:03 -05:00
* @ param string [] $removable_query_args An array of query variable names to remove from a URL .
2015-09-02 07:29:23 -04:00
*/
return apply_filters ( 'removable_query_args' , $removable_query_args );
}
2008-06-15 05:38:32 -04:00
/**
* Walks the array while sanitizing the contents .
*
2008-08-10 12:45:50 -04:00
* @ since 0.71
2020-06-28 17:04:02 -04:00
* @ since 5.5 . 0 Non - string values are left untouched .
2008-06-15 05:38:32 -04:00
*
Code Modernization: Rename parameters that use reserved keywords in `wp-includes/functions.php`.
While using reserved PHP keywords as parameter name labels is allowed, in the context of function calls using named parameters in PHP 8.0+, this will easily lead to confusion. To avoid that, it is recommended not to use reserved keywords as function parameter names.
This commit:
* Renames the `$echo` parameter to `$display` in:
* `wp_nonce_field()`
* `wp_referer_field()`
* `wp_original_referer_field()`
* Renames the `$string` parameter to `$input_string` in
* `_wp_json_convert_string()`
* `_wp_to_kebab_case()`
* Renames the `$list` parameter to `$input_list` in:
* `wp_parse_list()`
* `wp_parse_id_list()`
* `wp_parse_slug_list()`
* `wp_filter_object_list()`
* `wp_list_filter()`
* `wp_list_pluck()`
* `wp_list_sort()`
* Renames the `$array` parameter to `$input_array` in:
* `add_magic_quotes()`
* `wp_array_slice_assoc()`
* `_wp_array_get()`
* `_wp_array_set()`
* Renames the `$function` parameter to `$function_name` in:
* `_deprecated_function()`
* `_deprecated_argument()`
* `_doing_it_wrong()`
* Renames the `$class` parameter to `$class_name` in `_deprecated_constructor()`.
* Renames the `$default` parameter to `$default_value` in `apache_mod_loaded()`.
* Renames the `$var` parameter to `$value` in `wp_validate_boolean()`.
* Amends the `$input` parameter in `wp_parse_str()` for consistency.
Follow-up to [52946], [52996], [52997], [52998], [53003], [53014], [53029], [53039], [53116], [53117], [53137], [53174], [53184], [53185], [53192], [53193], [53198], [53203], [53207], [53215], [53216], [53220], [53230], [53232], [53236], [53239], [53240], [53242], [53243], [53245], [53246], [53257], [53269], [53270], [53271], [53272], [53273], [53274], [53275], [53276], [53277], [53281], [53283], [53284], [53285], [53287], [53364], [53365], [54927].
Props jrf, aristath, poena, justinahinon, SergeyBiryukov.
See #56788.
Built from https://develop.svn.wordpress.org/trunk@54929
git-svn-id: http://core.svn.wordpress.org/trunk@54481 1a063a9b-81f0-0310-95a4-ce76da25c4cd
2022-12-03 10:07:14 -05:00
* @ param array $input_array Array to walk while sanitizing contents .
* @ return array Sanitized $input_array .
2008-06-15 05:38:32 -04:00
*/
Code Modernization: Rename parameters that use reserved keywords in `wp-includes/functions.php`.
While using reserved PHP keywords as parameter name labels is allowed, in the context of function calls using named parameters in PHP 8.0+, this will easily lead to confusion. To avoid that, it is recommended not to use reserved keywords as function parameter names.
This commit:
* Renames the `$echo` parameter to `$display` in:
* `wp_nonce_field()`
* `wp_referer_field()`
* `wp_original_referer_field()`
* Renames the `$string` parameter to `$input_string` in
* `_wp_json_convert_string()`
* `_wp_to_kebab_case()`
* Renames the `$list` parameter to `$input_list` in:
* `wp_parse_list()`
* `wp_parse_id_list()`
* `wp_parse_slug_list()`
* `wp_filter_object_list()`
* `wp_list_filter()`
* `wp_list_pluck()`
* `wp_list_sort()`
* Renames the `$array` parameter to `$input_array` in:
* `add_magic_quotes()`
* `wp_array_slice_assoc()`
* `_wp_array_get()`
* `_wp_array_set()`
* Renames the `$function` parameter to `$function_name` in:
* `_deprecated_function()`
* `_deprecated_argument()`
* `_doing_it_wrong()`
* Renames the `$class` parameter to `$class_name` in `_deprecated_constructor()`.
* Renames the `$default` parameter to `$default_value` in `apache_mod_loaded()`.
* Renames the `$var` parameter to `$value` in `wp_validate_boolean()`.
* Amends the `$input` parameter in `wp_parse_str()` for consistency.
Follow-up to [52946], [52996], [52997], [52998], [53003], [53014], [53029], [53039], [53116], [53117], [53137], [53174], [53184], [53185], [53192], [53193], [53198], [53203], [53207], [53215], [53216], [53220], [53230], [53232], [53236], [53239], [53240], [53242], [53243], [53245], [53246], [53257], [53269], [53270], [53271], [53272], [53273], [53274], [53275], [53276], [53277], [53281], [53283], [53284], [53285], [53287], [53364], [53365], [54927].
Props jrf, aristath, poena, justinahinon, SergeyBiryukov.
See #56788.
Built from https://develop.svn.wordpress.org/trunk@54929
git-svn-id: http://core.svn.wordpress.org/trunk@54481 1a063a9b-81f0-0310-95a4-ce76da25c4cd
2022-12-03 10:07:14 -05:00
function add_magic_quotes ( $input_array ) {
foreach ( ( array ) $input_array as $k => $v ) {
2007-10-11 01:46:57 -04:00
if ( is_array ( $v ) ) {
Code Modernization: Rename parameters that use reserved keywords in `wp-includes/functions.php`.
While using reserved PHP keywords as parameter name labels is allowed, in the context of function calls using named parameters in PHP 8.0+, this will easily lead to confusion. To avoid that, it is recommended not to use reserved keywords as function parameter names.
This commit:
* Renames the `$echo` parameter to `$display` in:
* `wp_nonce_field()`
* `wp_referer_field()`
* `wp_original_referer_field()`
* Renames the `$string` parameter to `$input_string` in
* `_wp_json_convert_string()`
* `_wp_to_kebab_case()`
* Renames the `$list` parameter to `$input_list` in:
* `wp_parse_list()`
* `wp_parse_id_list()`
* `wp_parse_slug_list()`
* `wp_filter_object_list()`
* `wp_list_filter()`
* `wp_list_pluck()`
* `wp_list_sort()`
* Renames the `$array` parameter to `$input_array` in:
* `add_magic_quotes()`
* `wp_array_slice_assoc()`
* `_wp_array_get()`
* `_wp_array_set()`
* Renames the `$function` parameter to `$function_name` in:
* `_deprecated_function()`
* `_deprecated_argument()`
* `_doing_it_wrong()`
* Renames the `$class` parameter to `$class_name` in `_deprecated_constructor()`.
* Renames the `$default` parameter to `$default_value` in `apache_mod_loaded()`.
* Renames the `$var` parameter to `$value` in `wp_validate_boolean()`.
* Amends the `$input` parameter in `wp_parse_str()` for consistency.
Follow-up to [52946], [52996], [52997], [52998], [53003], [53014], [53029], [53039], [53116], [53117], [53137], [53174], [53184], [53185], [53192], [53193], [53198], [53203], [53207], [53215], [53216], [53220], [53230], [53232], [53236], [53239], [53240], [53242], [53243], [53245], [53246], [53257], [53269], [53270], [53271], [53272], [53273], [53274], [53275], [53276], [53277], [53281], [53283], [53284], [53285], [53287], [53364], [53365], [54927].
Props jrf, aristath, poena, justinahinon, SergeyBiryukov.
See #56788.
Built from https://develop.svn.wordpress.org/trunk@54929
git-svn-id: http://core.svn.wordpress.org/trunk@54481 1a063a9b-81f0-0310-95a4-ce76da25c4cd
2022-12-03 10:07:14 -05:00
$input_array [ $k ] = add_magic_quotes ( $v );
2020-07-11 18:44:05 -04:00
} elseif ( is_string ( $v ) ) {
Code Modernization: Rename parameters that use reserved keywords in `wp-includes/functions.php`.
While using reserved PHP keywords as parameter name labels is allowed, in the context of function calls using named parameters in PHP 8.0+, this will easily lead to confusion. To avoid that, it is recommended not to use reserved keywords as function parameter names.
This commit:
* Renames the `$echo` parameter to `$display` in:
* `wp_nonce_field()`
* `wp_referer_field()`
* `wp_original_referer_field()`
* Renames the `$string` parameter to `$input_string` in
* `_wp_json_convert_string()`
* `_wp_to_kebab_case()`
* Renames the `$list` parameter to `$input_list` in:
* `wp_parse_list()`
* `wp_parse_id_list()`
* `wp_parse_slug_list()`
* `wp_filter_object_list()`
* `wp_list_filter()`
* `wp_list_pluck()`
* `wp_list_sort()`
* Renames the `$array` parameter to `$input_array` in:
* `add_magic_quotes()`
* `wp_array_slice_assoc()`
* `_wp_array_get()`
* `_wp_array_set()`
* Renames the `$function` parameter to `$function_name` in:
* `_deprecated_function()`
* `_deprecated_argument()`
* `_doing_it_wrong()`
* Renames the `$class` parameter to `$class_name` in `_deprecated_constructor()`.
* Renames the `$default` parameter to `$default_value` in `apache_mod_loaded()`.
* Renames the `$var` parameter to `$value` in `wp_validate_boolean()`.
* Amends the `$input` parameter in `wp_parse_str()` for consistency.
Follow-up to [52946], [52996], [52997], [52998], [53003], [53014], [53029], [53039], [53116], [53117], [53137], [53174], [53184], [53185], [53192], [53193], [53198], [53203], [53207], [53215], [53216], [53220], [53230], [53232], [53236], [53239], [53240], [53242], [53243], [53245], [53246], [53257], [53269], [53270], [53271], [53272], [53273], [53274], [53275], [53276], [53277], [53281], [53283], [53284], [53285], [53287], [53364], [53365], [54927].
Props jrf, aristath, poena, justinahinon, SergeyBiryukov.
See #56788.
Built from https://develop.svn.wordpress.org/trunk@54929
git-svn-id: http://core.svn.wordpress.org/trunk@54481 1a063a9b-81f0-0310-95a4-ce76da25c4cd
2022-12-03 10:07:14 -05:00
$input_array [ $k ] = addslashes ( $v );
2020-07-11 18:44:05 -04:00
} else {
continue ;
2004-12-15 21:57:05 -05:00
}
}
2020-06-28 17:04:02 -04:00
Code Modernization: Rename parameters that use reserved keywords in `wp-includes/functions.php`.
While using reserved PHP keywords as parameter name labels is allowed, in the context of function calls using named parameters in PHP 8.0+, this will easily lead to confusion. To avoid that, it is recommended not to use reserved keywords as function parameter names.
This commit:
* Renames the `$echo` parameter to `$display` in:
* `wp_nonce_field()`
* `wp_referer_field()`
* `wp_original_referer_field()`
* Renames the `$string` parameter to `$input_string` in
* `_wp_json_convert_string()`
* `_wp_to_kebab_case()`
* Renames the `$list` parameter to `$input_list` in:
* `wp_parse_list()`
* `wp_parse_id_list()`
* `wp_parse_slug_list()`
* `wp_filter_object_list()`
* `wp_list_filter()`
* `wp_list_pluck()`
* `wp_list_sort()`
* Renames the `$array` parameter to `$input_array` in:
* `add_magic_quotes()`
* `wp_array_slice_assoc()`
* `_wp_array_get()`
* `_wp_array_set()`
* Renames the `$function` parameter to `$function_name` in:
* `_deprecated_function()`
* `_deprecated_argument()`
* `_doing_it_wrong()`
* Renames the `$class` parameter to `$class_name` in `_deprecated_constructor()`.
* Renames the `$default` parameter to `$default_value` in `apache_mod_loaded()`.
* Renames the `$var` parameter to `$value` in `wp_validate_boolean()`.
* Amends the `$input` parameter in `wp_parse_str()` for consistency.
Follow-up to [52946], [52996], [52997], [52998], [53003], [53014], [53029], [53039], [53116], [53117], [53137], [53174], [53184], [53185], [53192], [53193], [53198], [53203], [53207], [53215], [53216], [53220], [53230], [53232], [53236], [53239], [53240], [53242], [53243], [53245], [53246], [53257], [53269], [53270], [53271], [53272], [53273], [53274], [53275], [53276], [53277], [53281], [53283], [53284], [53285], [53287], [53364], [53365], [54927].
Props jrf, aristath, poena, justinahinon, SergeyBiryukov.
See #56788.
Built from https://develop.svn.wordpress.org/trunk@54929
git-svn-id: http://core.svn.wordpress.org/trunk@54481 1a063a9b-81f0-0310-95a4-ce76da25c4cd
2022-12-03 10:07:14 -05:00
return $input_array ;
2004-12-15 21:57:05 -05:00
}
2008-06-29 23:23:44 -04:00
/**
* HTTP request for URI to retrieve content .
*
2008-08-10 12:45:50 -04:00
* @ since 1.5 . 1
2014-06-30 21:44:15 -04:00
*
* @ see wp_safe_remote_get ()
2008-06-29 23:23:44 -04:00
*
* @ param string $uri URI / URL of web page to retrieve .
2020-01-11 13:32:05 -05:00
* @ return string | false HTTP content . False on failure .
2008-06-29 23:23:44 -04:00
*/
2005-05-03 03:52:11 -04:00
function wp_remote_fopen ( $uri ) {
2020-04-24 03:28:10 -04:00
$parsed_url = parse_url ( $uri );
2007-01-16 13:41:05 -05:00
2017-11-30 18:11:00 -05:00
if ( ! $parsed_url || ! is_array ( $parsed_url ) ) {
2007-01-16 13:41:05 -05:00
return false ;
2017-11-30 18:11:00 -05:00
}
2007-01-16 13:41:05 -05:00
2017-11-30 18:11:00 -05:00
$options = array ();
2008-09-27 17:41:19 -04:00
$options [ 'timeout' ] = 10 ;
2007-01-16 13:41:05 -05:00
2013-07-31 02:52:13 -04:00
$response = wp_safe_remote_get ( $uri , $options );
2007-01-16 13:41:05 -05:00
2017-11-30 18:11:00 -05:00
if ( is_wp_error ( $response ) ) {
2008-10-01 20:32:21 -04:00
return false ;
2017-11-30 18:11:00 -05:00
}
2008-10-01 20:32:21 -04:00
2011-05-14 15:45:07 -04:00
return wp_remote_retrieve_body ( $response );
2005-05-03 03:52:11 -04:00
}
2008-08-09 00:51:51 -04:00
/**
2022-08-12 05:53:11 -04:00
* Sets up the WordPress query .
2008-08-09 00:51:51 -04:00
*
* @ since 2.0 . 0
*
2019-08-03 21:28:55 -04:00
* @ global WP $wp Current WordPress environment instance .
2019-08-03 21:59:56 -04:00
* @ global WP_Query $wp_query WordPress Query object .
* @ global WP_Query $wp_the_query Copy of the WordPress Query object .
2015-05-25 12:11:25 -04:00
*
2015-01-16 14:03:23 -05:00
* @ param string | array $query_vars Default WP_Query arguments .
2008-08-09 00:51:51 -04:00
*/
2007-10-11 01:46:57 -04:00
function wp ( $query_vars = '' ) {
2007-10-12 17:47:34 -04:00
global $wp , $wp_query , $wp_the_query ;
2020-02-08 00:31:07 -05:00
2007-10-11 01:46:57 -04:00
$wp -> main ( $query_vars );
2007-10-12 17:47:34 -04:00
2017-11-30 18:11:00 -05:00
if ( ! isset ( $wp_the_query ) ) {
2007-10-12 17:47:34 -04:00
$wp_the_query = $wp_query ;
2017-11-30 18:11:00 -05:00
}
2005-06-10 19:15:13 -04:00
}
2008-06-15 05:38:32 -04:00
/**
2022-08-12 05:53:11 -04:00
* Retrieves the description for the HTTP status .
2008-06-15 05:38:32 -04:00
*
* @ since 2.3 . 0
2017-11-20 15:35:48 -05:00
* @ since 3.9 . 0 Added status codes 418 , 428 , 429 , 431 , and 511.
* @ since 4.5 . 0 Added status codes 308 , 421 , and 451.
2019-01-03 10:21:52 -05:00
* @ since 5.1 . 0 Added status code 103.
2008-06-15 05:38:32 -04:00
*
2015-05-25 12:11:25 -04:00
* @ global array $wp_header_to_desc
*
2008-06-15 05:38:32 -04:00
* @ param int $code HTTP status code .
2019-09-14 10:54:56 -04:00
* @ return string Status description if found , an empty string otherwise .
2008-06-15 05:38:32 -04:00
*/
2007-05-10 23:34:50 -04:00
function get_status_header_desc ( $code ) {
global $wp_header_to_desc ;
2007-06-13 22:25:30 -04:00
2007-10-11 01:46:57 -04:00
$code = absint ( $code );
2007-06-13 22:25:30 -04:00
2017-11-30 18:11:00 -05:00
if ( ! isset ( $wp_header_to_desc ) ) {
2007-09-13 00:48:41 -04:00
$wp_header_to_desc = array (
100 => 'Continue' ,
101 => 'Switching Protocols' ,
2009-03-07 16:05:54 -05:00
102 => 'Processing' ,
2017-11-20 15:35:48 -05:00
103 => 'Early Hints' ,
2007-09-13 00:48:41 -04:00
200 => 'OK' ,
201 => 'Created' ,
202 => 'Accepted' ,
203 => 'Non-Authoritative Information' ,
204 => 'No Content' ,
205 => 'Reset Content' ,
206 => 'Partial Content' ,
2009-03-07 16:05:54 -05:00
207 => 'Multi-Status' ,
226 => 'IM Used' ,
2007-09-13 00:48:41 -04:00
300 => 'Multiple Choices' ,
301 => 'Moved Permanently' ,
302 => 'Found' ,
303 => 'See Other' ,
304 => 'Not Modified' ,
305 => 'Use Proxy' ,
2009-03-07 16:05:54 -05:00
306 => 'Reserved' ,
2007-09-13 00:48:41 -04:00
307 => 'Temporary Redirect' ,
2016-01-12 21:55:26 -05:00
308 => 'Permanent Redirect' ,
2007-09-13 00:48:41 -04:00
400 => 'Bad Request' ,
401 => 'Unauthorized' ,
2009-03-07 16:05:54 -05:00
402 => 'Payment Required' ,
2007-09-13 00:48:41 -04:00
403 => 'Forbidden' ,
404 => 'Not Found' ,
405 => 'Method Not Allowed' ,
406 => 'Not Acceptable' ,
407 => 'Proxy Authentication Required' ,
408 => 'Request Timeout' ,
409 => 'Conflict' ,
410 => 'Gone' ,
411 => 'Length Required' ,
412 => 'Precondition Failed' ,
413 => 'Request Entity Too Large' ,
414 => 'Request-URI Too Long' ,
415 => 'Unsupported Media Type' ,
416 => 'Requested Range Not Satisfiable' ,
417 => 'Expectation Failed' ,
2014-03-05 17:01:16 -05:00
418 => 'I\'m a teapot' ,
2016-01-12 21:55:26 -05:00
421 => 'Misdirected Request' ,
2009-03-07 16:05:54 -05:00
422 => 'Unprocessable Entity' ,
423 => 'Locked' ,
424 => 'Failed Dependency' ,
426 => 'Upgrade Required' ,
2014-03-05 17:01:16 -05:00
428 => 'Precondition Required' ,
429 => 'Too Many Requests' ,
431 => 'Request Header Fields Too Large' ,
2016-01-12 21:49:25 -05:00
451 => 'Unavailable For Legal Reasons' ,
2007-09-13 00:48:41 -04:00
500 => 'Internal Server Error' ,
501 => 'Not Implemented' ,
502 => 'Bad Gateway' ,
503 => 'Service Unavailable' ,
504 => 'Gateway Timeout' ,
2009-03-07 16:05:54 -05:00
505 => 'HTTP Version Not Supported' ,
506 => 'Variant Also Negotiates' ,
507 => 'Insufficient Storage' ,
2014-03-05 17:01:16 -05:00
510 => 'Not Extended' ,
511 => 'Network Authentication Required' ,
2007-09-13 00:48:41 -04:00
);
}
2017-11-30 18:11:00 -05:00
if ( isset ( $wp_header_to_desc [ $code ] ) ) {
return $wp_header_to_desc [ $code ];
} else {
2007-05-10 23:34:50 -04:00
return '' ;
2017-11-30 18:11:00 -05:00
}
2007-05-10 23:34:50 -04:00
}
2008-06-29 23:23:44 -04:00
/**
2022-08-12 05:53:11 -04:00
* Sets HTTP status header .
2008-06-29 23:23:44 -04:00
*
2008-08-10 12:45:50 -04:00
* @ since 2.0 . 0
2015-10-07 17:26:25 -04:00
* @ since 4.4 . 0 Added the `$description` parameter .
2014-06-30 21:44:15 -04:00
*
2013-10-30 10:39:10 -04:00
* @ see get_status_header_desc ()
2008-06-29 23:23:44 -04:00
*
2015-10-07 17:26:25 -04:00
* @ param int $code HTTP status code .
* @ param string $description Optional . A custom description for the HTTP status .
2023-02-21 11:39:19 -05:00
* Defaults to the result of get_status_header_desc () for the given code .
2008-06-29 23:23:44 -04:00
*/
2015-10-07 17:26:25 -04:00
function status_header ( $code , $description = '' ) {
if ( ! $description ) {
$description = get_status_header_desc ( $code );
}
2007-06-13 22:25:30 -04:00
2015-10-07 17:26:25 -04:00
if ( empty ( $description ) ) {
2013-10-30 10:39:10 -04:00
return ;
2015-10-07 17:26:25 -04:00
}
2007-05-12 17:55:14 -04:00
2017-11-30 18:11:00 -05:00
$protocol = wp_get_server_protocol ();
2013-10-30 10:39:10 -04:00
$status_header = " $protocol $code $description " ;
2017-11-30 18:11:00 -05:00
if ( function_exists ( 'apply_filters' ) ) {
2014-04-13 20:20:14 -04:00
/**
2016-05-22 14:36:27 -04:00
* Filters an HTTP status header .
2014-04-13 20:20:14 -04:00
*
* @ since 2.2 . 0
*
* @ param string $status_header HTTP status header .
* @ param int $code HTTP status code .
* @ param string $description Description for the status code .
* @ param string $protocol Server protocol .
*/
2013-10-30 10:39:10 -04:00
$status_header = apply_filters ( 'status_header' , $status_header , $code , $description , $protocol );
2017-11-30 18:11:00 -05:00
}
2007-05-12 17:55:14 -04:00
2019-07-09 01:45:58 -04:00
if ( ! headers_sent () ) {
header ( $status_header , true , $code );
}
2005-06-08 20:17:43 -04:00
}
2009-02-21 16:39:06 -05:00
/**
Administration: Add the `no-store` and `private` directives to the `Cache-Control` header when preventing caching for logged in users.
The intention behind this change is to prevent sensitive data in responses for logged in users being cached and available to others, for example via the browser history after the user logs out.
The `no-store` directive instructs caches in the browser or within proxies not to store the response in the cache. This is subtly different from the `no-cache` directive which means the response can be cached but must be revalidated before re-use. WordPress does not use ETag headers by default therefore this does not achieve the same result.
The `private` directive complements the `no-store` directive by specifying that the response contains private information that should not be stored in a public cache. Som
e proxy caches may ignore the `no-store` directive but respect the `private` directive, thus it is included.
The existing `Cache-Control` header for users who are not logged in remains unchanged, and the existing cache prevention directives remain in place for backwards compatib
ility.
Props soulseekah, luehrsen, Dharm1025, markdoliner, rutviksavsani, ayeshrajans, paulkevan, clorith, andy786, johnbillion
Fixes #21938, Fixes #57627
Built from https://develop.svn.wordpress.org/trunk@55968
git-svn-id: http://core.svn.wordpress.org/trunk@55480 1a063a9b-81f0-0310-95a4-ce76da25c4cd
2023-06-21 14:27:18 -04:00
* Gets the HTTP header information to prevent caching .
2009-02-21 16:39:06 -05:00
*
2014-06-30 21:44:15 -04:00
* The several different headers cover the different ways cache prevention
Administration: Add the `no-store` and `private` directives to the `Cache-Control` header when preventing caching for logged in users.
The intention behind this change is to prevent sensitive data in responses for logged in users being cached and available to others, for example via the browser history after the user logs out.
The `no-store` directive instructs caches in the browser or within proxies not to store the response in the cache. This is subtly different from the `no-cache` directive which means the response can be cached but must be revalidated before re-use. WordPress does not use ETag headers by default therefore this does not achieve the same result.
The `private` directive complements the `no-store` directive by specifying that the response contains private information that should not be stored in a public cache. Som
e proxy caches may ignore the `no-store` directive but respect the `private` directive, thus it is included.
The existing `Cache-Control` header for users who are not logged in remains unchanged, and the existing cache prevention directives remain in place for backwards compatib
ility.
Props soulseekah, luehrsen, Dharm1025, markdoliner, rutviksavsani, ayeshrajans, paulkevan, clorith, andy786, johnbillion
Fixes #21938, Fixes #57627
Built from https://develop.svn.wordpress.org/trunk@55968
git-svn-id: http://core.svn.wordpress.org/trunk@55480 1a063a9b-81f0-0310-95a4-ce76da25c4cd
2023-06-21 14:27:18 -04:00
* is handled by different browsers .
2009-02-21 16:39:06 -05:00
*
2010-12-01 14:24:38 -05:00
* @ since 2.8 . 0
Administration: Add the `no-store` and `private` directives to the `Cache-Control` header when preventing caching for logged in users.
The intention behind this change is to prevent sensitive data in responses for logged in users being cached and available to others, for example via the browser history after the user logs out.
The `no-store` directive instructs caches in the browser or within proxies not to store the response in the cache. This is subtly different from the `no-cache` directive which means the response can be cached but must be revalidated before re-use. WordPress does not use ETag headers by default therefore this does not achieve the same result.
The `private` directive complements the `no-store` directive by specifying that the response contains private information that should not be stored in a public cache. Som
e proxy caches may ignore the `no-store` directive but respect the `private` directive, thus it is included.
The existing `Cache-Control` header for users who are not logged in remains unchanged, and the existing cache prevention directives remain in place for backwards compatib
ility.
Props soulseekah, luehrsen, Dharm1025, markdoliner, rutviksavsani, ayeshrajans, paulkevan, clorith, andy786, johnbillion
Fixes #21938, Fixes #57627
Built from https://develop.svn.wordpress.org/trunk@55968
git-svn-id: http://core.svn.wordpress.org/trunk@55480 1a063a9b-81f0-0310-95a4-ce76da25c4cd
2023-06-21 14:27:18 -04:00
* @ since 6.3 . 0 The `Cache-Control` header for logged in users now includes the
* `no-store` and `private` directives .
2009-02-21 16:39:06 -05:00
*
* @ return array The associative array of header names and field values .
*/
function wp_get_nocache_headers () {
Administration: Add the `no-store` and `private` directives to the `Cache-Control` header when preventing caching for logged in users.
The intention behind this change is to prevent sensitive data in responses for logged in users being cached and available to others, for example via the browser history after the user logs out.
The `no-store` directive instructs caches in the browser or within proxies not to store the response in the cache. This is subtly different from the `no-cache` directive which means the response can be cached but must be revalidated before re-use. WordPress does not use ETag headers by default therefore this does not achieve the same result.
The `private` directive complements the `no-store` directive by specifying that the response contains private information that should not be stored in a public cache. Som
e proxy caches may ignore the `no-store` directive but respect the `private` directive, thus it is included.
The existing `Cache-Control` header for users who are not logged in remains unchanged, and the existing cache prevention directives remain in place for backwards compatib
ility.
Props soulseekah, luehrsen, Dharm1025, markdoliner, rutviksavsani, ayeshrajans, paulkevan, clorith, andy786, johnbillion
Fixes #21938, Fixes #57627
Built from https://develop.svn.wordpress.org/trunk@55968
git-svn-id: http://core.svn.wordpress.org/trunk@55480 1a063a9b-81f0-0310-95a4-ce76da25c4cd
2023-06-21 14:27:18 -04:00
$cache_control = ( function_exists ( 'is_user_logged_in' ) && is_user_logged_in () )
? 'no-cache, must-revalidate, max-age=0, no-store, private'
: 'no-cache, must-revalidate, max-age=0' ;
2009-02-21 16:39:06 -05:00
$headers = array (
2017-11-30 18:11:00 -05:00
'Expires' => 'Wed, 11 Jan 1984 05:00:00 GMT' ,
Administration: Add the `no-store` and `private` directives to the `Cache-Control` header when preventing caching for logged in users.
The intention behind this change is to prevent sensitive data in responses for logged in users being cached and available to others, for example via the browser history after the user logs out.
The `no-store` directive instructs caches in the browser or within proxies not to store the response in the cache. This is subtly different from the `no-cache` directive which means the response can be cached but must be revalidated before re-use. WordPress does not use ETag headers by default therefore this does not achieve the same result.
The `private` directive complements the `no-store` directive by specifying that the response contains private information that should not be stored in a public cache. Som
e proxy caches may ignore the `no-store` directive but respect the `private` directive, thus it is included.
The existing `Cache-Control` header for users who are not logged in remains unchanged, and the existing cache prevention directives remain in place for backwards compatib
ility.
Props soulseekah, luehrsen, Dharm1025, markdoliner, rutviksavsani, ayeshrajans, paulkevan, clorith, andy786, johnbillion
Fixes #21938, Fixes #57627
Built from https://develop.svn.wordpress.org/trunk@55968
git-svn-id: http://core.svn.wordpress.org/trunk@55480 1a063a9b-81f0-0310-95a4-ce76da25c4cd
2023-06-21 14:27:18 -04:00
'Cache-Control' => $cache_control ,
2009-02-21 16:39:06 -05:00
);
2009-03-17 22:43:45 -04:00
2017-11-30 18:11:00 -05:00
if ( function_exists ( 'apply_filters' ) ) {
2014-04-13 20:20:14 -04:00
/**
Administration: Add the `no-store` and `private` directives to the `Cache-Control` header when preventing caching for logged in users.
The intention behind this change is to prevent sensitive data in responses for logged in users being cached and available to others, for example via the browser history after the user logs out.
The `no-store` directive instructs caches in the browser or within proxies not to store the response in the cache. This is subtly different from the `no-cache` directive which means the response can be cached but must be revalidated before re-use. WordPress does not use ETag headers by default therefore this does not achieve the same result.
The `private` directive complements the `no-store` directive by specifying that the response contains private information that should not be stored in a public cache. Som
e proxy caches may ignore the `no-store` directive but respect the `private` directive, thus it is included.
The existing `Cache-Control` header for users who are not logged in remains unchanged, and the existing cache prevention directives remain in place for backwards compatib
ility.
Props soulseekah, luehrsen, Dharm1025, markdoliner, rutviksavsani, ayeshrajans, paulkevan, clorith, andy786, johnbillion
Fixes #21938, Fixes #57627
Built from https://develop.svn.wordpress.org/trunk@55968
git-svn-id: http://core.svn.wordpress.org/trunk@55480 1a063a9b-81f0-0310-95a4-ce76da25c4cd
2023-06-21 14:27:18 -04:00
* Filters the cache - controlling HTTP headers that are used to prevent caching .
2014-04-13 20:20:14 -04:00
*
* @ since 2.8 . 0
*
2014-06-30 21:44:15 -04:00
* @ see wp_get_nocache_headers ()
*
2022-09-20 16:32:09 -04:00
* @ param array $headers Header names and field values .
2014-04-13 20:20:14 -04:00
*/
$headers = ( array ) apply_filters ( 'nocache_headers' , $headers );
2009-02-22 05:09:30 -05:00
}
2013-01-04 14:51:31 -05:00
$headers [ 'Last-Modified' ] = false ;
2009-02-22 05:09:30 -05:00
return $headers ;
2009-02-21 16:39:06 -05:00
}
2008-06-15 05:38:32 -04:00
/**
Administration: Add the `no-store` and `private` directives to the `Cache-Control` header when preventing caching for logged in users.
The intention behind this change is to prevent sensitive data in responses for logged in users being cached and available to others, for example via the browser history after the user logs out.
The `no-store` directive instructs caches in the browser or within proxies not to store the response in the cache. This is subtly different from the `no-cache` directive which means the response can be cached but must be revalidated before re-use. WordPress does not use ETag headers by default therefore this does not achieve the same result.
The `private` directive complements the `no-store` directive by specifying that the response contains private information that should not be stored in a public cache. Som
e proxy caches may ignore the `no-store` directive but respect the `private` directive, thus it is included.
The existing `Cache-Control` header for users who are not logged in remains unchanged, and the existing cache prevention directives remain in place for backwards compatib
ility.
Props soulseekah, luehrsen, Dharm1025, markdoliner, rutviksavsani, ayeshrajans, paulkevan, clorith, andy786, johnbillion
Fixes #21938, Fixes #57627
Built from https://develop.svn.wordpress.org/trunk@55968
git-svn-id: http://core.svn.wordpress.org/trunk@55480 1a063a9b-81f0-0310-95a4-ce76da25c4cd
2023-06-21 14:27:18 -04:00
* Sets the HTTP headers to prevent caching for the different browsers .
2008-06-15 05:38:32 -04:00
*
2014-06-30 21:44:15 -04:00
* Different browsers support different nocache headers , so several
* headers must be sent so that all of them get the point that no
* caching should occur .
2008-06-15 05:38:32 -04:00
*
* @ since 2.0 . 0
2014-06-30 21:44:15 -04:00
*
2013-10-30 10:39:10 -04:00
* @ see wp_get_nocache_headers ()
2008-06-15 05:38:32 -04:00
*/
2005-06-08 20:17:43 -04:00
function nocache_headers () {
2019-07-09 01:45:58 -04:00
if ( headers_sent () ) {
return ;
}
2009-02-21 16:39:06 -05:00
$headers = wp_get_nocache_headers ();
2013-01-04 14:51:31 -05:00
unset ( $headers [ 'Last-Modified' ] );
2019-07-09 01:45:58 -04:00
header_remove ( 'Last-Modified' );
2013-01-04 14:51:31 -05:00
2017-11-30 18:11:00 -05:00
foreach ( $headers as $name => $field_value ) {
2019-07-09 01:45:58 -04:00
header ( " { $name } : { $field_value } " );
2017-11-30 18:11:00 -05:00
}
2005-06-08 20:17:43 -04:00
}
2008-06-15 05:38:32 -04:00
/**
Administration: Add the `no-store` and `private` directives to the `Cache-Control` header when preventing caching for logged in users.
The intention behind this change is to prevent sensitive data in responses for logged in users being cached and available to others, for example via the browser history after the user logs out.
The `no-store` directive instructs caches in the browser or within proxies not to store the response in the cache. This is subtly different from the `no-cache` directive which means the response can be cached but must be revalidated before re-use. WordPress does not use ETag headers by default therefore this does not achieve the same result.
The `private` directive complements the `no-store` directive by specifying that the response contains private information that should not be stored in a public cache. Som
e proxy caches may ignore the `no-store` directive but respect the `private` directive, thus it is included.
The existing `Cache-Control` header for users who are not logged in remains unchanged, and the existing cache prevention directives remain in place for backwards compatib
ility.
Props soulseekah, luehrsen, Dharm1025, markdoliner, rutviksavsani, ayeshrajans, paulkevan, clorith, andy786, johnbillion
Fixes #21938, Fixes #57627
Built from https://develop.svn.wordpress.org/trunk@55968
git-svn-id: http://core.svn.wordpress.org/trunk@55480 1a063a9b-81f0-0310-95a4-ce76da25c4cd
2023-06-21 14:27:18 -04:00
* Sets the HTTP headers for caching for 10 days with JavaScript content type .
2008-06-15 05:38:32 -04:00
*
* @ since 2.1 . 0
*/
2006-08-22 13:31:53 -04:00
function cache_javascript_headers () {
2012-09-25 01:26:19 -04:00
$expiresOffset = 10 * DAY_IN_SECONDS ;
2014-06-30 21:44:15 -04:00
2017-11-30 18:11:00 -05:00
header ( 'Content-Type: text/javascript; charset=' . get_bloginfo ( 'charset' ) );
2020-01-28 19:45:18 -05:00
header ( 'Vary: Accept-Encoding' ); // Handle proxies.
2017-11-30 18:11:00 -05:00
header ( 'Expires: ' . gmdate ( 'D, d M Y H:i:s' , time () + $expiresOffset ) . ' GMT' );
2006-08-22 13:31:53 -04:00
}
2008-06-15 05:38:32 -04:00
/**
2022-08-12 05:53:11 -04:00
* Retrieves the number of database queries during the WordPress execution .
2008-06-15 05:38:32 -04:00
*
* @ since 2.0 . 0
*
2014-10-31 13:56:22 -04:00
* @ global wpdb $wpdb WordPress database abstraction object .
2014-06-30 21:44:15 -04:00
*
* @ return int Number of database queries .
2008-06-15 05:38:32 -04:00
*/
2005-11-16 18:48:12 -05:00
function get_num_queries () {
global $wpdb ;
return $wpdb -> num_queries ;
}
2008-06-15 05:38:32 -04:00
/**
2022-08-12 05:53:11 -04:00
* Determines whether input is yes or no .
2014-06-30 21:44:15 -04:00
*
* Must be 'y' to be true .
2008-06-15 05:38:32 -04:00
*
* @ since 1.0 . 0
*
2014-06-30 21:44:15 -04:00
* @ param string $yn Character string containing either 'y' ( yes ) or 'n' ( no ) .
2021-10-04 16:44:02 -04:00
* @ return bool True if 'y' , false on anything else .
2008-06-15 05:38:32 -04:00
*/
2007-05-28 13:11:42 -04:00
function bool_from_yn ( $yn ) {
2020-05-16 14:42:12 -04:00
return ( 'y' === strtolower ( $yn ) );
2006-02-26 23:57:30 -05:00
}
2006-03-12 17:57:00 -05:00
2008-08-09 00:51:51 -04:00
/**
2022-08-12 05:53:11 -04:00
* Loads the feed template from the use of an action hook .
2008-08-09 00:51:51 -04:00
*
* If the feed action does not have a hook , then the function will die with a
* message telling the visitor that the feed is not valid .
*
* It is better to only have one hook for each feed .
*
* @ since 2.1 . 0
2014-04-13 20:20:14 -04:00
*
2019-08-03 21:59:56 -04:00
* @ global WP_Query $wp_query WordPress Query object .
2008-08-09 00:51:51 -04:00
*/
2006-03-12 17:57:00 -05:00
function do_feed () {
2007-02-24 02:33:29 -05:00
global $wp_query ;
2007-10-11 01:46:57 -04:00
$feed = get_query_var ( 'feed' );
2006-03-12 17:57:00 -05:00
// Remove the pad, if present.
2007-10-11 01:46:57 -04:00
$feed = preg_replace ( '/^_+/' , '' , $feed );
2006-03-12 17:57:00 -05:00
2020-05-16 14:42:12 -04:00
if ( '' === $feed || 'feed' === $feed ) {
2007-12-06 14:58:15 -05:00
$feed = get_default_feed ();
2017-11-30 18:11:00 -05:00
}
2006-03-12 17:57:00 -05:00
2015-10-12 21:07:25 -04:00
if ( ! has_action ( " do_feed_ { $feed } " ) ) {
2022-07-14 10:10:11 -04:00
wp_die ( __ ( '<strong>Error:</strong> This is not a valid feed template.' ), '' , array ( 'response' => 404 ) );
2015-10-12 21:07:25 -04:00
}
2008-02-26 05:05:05 -05:00
2014-04-13 20:20:14 -04:00
/**
* Fires once the given feed is loaded .
*
2015-10-12 21:03:25 -04:00
* The dynamic portion of the hook name , `$feed` , refers to the feed template name .
2021-03-07 07:32:09 -05:00
*
* Possible hook names include :
*
* - `do_feed_atom`
* - `do_feed_rdf`
* - `do_feed_rss`
* - `do_feed_rss2`
2014-04-13 20:20:14 -04:00
*
* @ since 2.1 . 0
2015-10-12 22:44:23 -04:00
* @ since 4.4 . 0 The `$feed` parameter was added .
2014-04-13 20:20:14 -04:00
*
2015-10-12 22:44:23 -04:00
* @ param bool $is_comment_feed Whether the feed is a comment feed .
* @ param string $feed The feed name .
2014-04-13 20:20:14 -04:00
*/
2015-10-12 22:44:23 -04:00
do_action ( " do_feed_ { $feed } " , $wp_query -> is_comment_feed , $feed );
2006-03-12 17:57:00 -05:00
}
2008-06-15 05:38:32 -04:00
/**
2022-08-12 05:53:11 -04:00
* Loads the RDF RSS 0.91 Feed template .
2008-06-15 05:38:32 -04:00
*
* @ since 2.1 . 0
2014-06-30 21:44:15 -04:00
*
* @ see load_template ()
2008-06-15 05:38:32 -04:00
*/
2006-03-12 17:57:00 -05:00
function do_feed_rdf () {
2007-10-11 01:46:57 -04:00
load_template ( ABSPATH . WPINC . '/feed-rdf.php' );
2006-03-12 17:57:00 -05:00
}
2008-06-15 05:38:32 -04:00
/**
2022-08-12 05:53:11 -04:00
* Loads the RSS 1.0 Feed Template .
2008-06-15 05:38:32 -04:00
*
* @ since 2.1 . 0
2014-06-30 21:44:15 -04:00
*
* @ see load_template ()
2008-06-15 05:38:32 -04:00
*/
2006-03-12 17:57:00 -05:00
function do_feed_rss () {
2007-10-11 01:46:57 -04:00
load_template ( ABSPATH . WPINC . '/feed-rss.php' );
2006-03-12 17:57:00 -05:00
}
2008-06-15 05:38:32 -04:00
/**
2022-08-12 05:53:11 -04:00
* Loads either the RSS2 comment feed or the RSS2 posts feed .
2008-06-15 05:38:32 -04:00
*
* @ since 2.1 . 0
*
2014-06-30 21:44:15 -04:00
* @ see load_template ()
*
2008-06-15 05:38:32 -04:00
* @ param bool $for_comments True for the comment feed , false for normal feed .
*/
2007-10-11 01:46:57 -04:00
function do_feed_rss2 ( $for_comments ) {
2017-11-30 18:11:00 -05:00
if ( $for_comments ) {
2007-10-11 01:46:57 -04:00
load_template ( ABSPATH . WPINC . '/feed-rss2-comments.php' );
2017-11-30 18:11:00 -05:00
} else {
2007-10-11 01:46:57 -04:00
load_template ( ABSPATH . WPINC . '/feed-rss2.php' );
2017-11-30 18:11:00 -05:00
}
2006-03-12 17:57:00 -05:00
}
2008-06-15 05:38:32 -04:00
/**
2022-08-12 05:53:11 -04:00
* Loads either Atom comment feed or Atom posts feed .
2008-06-15 05:38:32 -04:00
*
* @ since 2.1 . 0
*
2014-06-30 21:44:15 -04:00
* @ see load_template ()
*
2008-06-15 05:38:32 -04:00
* @ param bool $for_comments True for the comment feed , false for normal feed .
*/
2007-10-11 01:46:57 -04:00
function do_feed_atom ( $for_comments ) {
2017-11-30 18:11:00 -05:00
if ( $for_comments ) {
load_template ( ABSPATH . WPINC . '/feed-atom-comments.php' );
} else {
2007-10-11 01:46:57 -04:00
load_template ( ABSPATH . WPINC . '/feed-atom.php' );
2017-11-30 18:11:00 -05:00
}
2006-03-12 17:57:00 -05:00
}
2006-03-31 03:07:39 -05:00
2008-06-15 05:38:32 -04:00
/**
2019-08-26 20:17:56 -04:00
* Displays the default robots . txt file content .
2008-06-15 05:38:32 -04:00
*
* @ since 2.1 . 0
2019-09-01 22:27:55 -04:00
* @ since 5.3 . 0 Remove the " Disallow: / " output if search engine visiblity is
Robots: Introduce Robots API.
This changeset introduces a filter-based Robots API, providing central control over the `robots` meta tag.
* Introduces `wp_robots()` function which should be called anywhere a `robots` meta tag should be included.
* Introduces `wp_robots` filter which allows adding or modifying directives for the `robots` meta tag. The `wp_robots()` function is entirely filter-based, i.e. if no filter is added to `wp_robots`, no directives will be present, and therefore the entire `robots` meta tag will be omitted.
* Introduces the following `wp_robots` filter functions which replace similar existing functions that were manually rendering a `robots` meta tag:
* `wp_robots_noindex()` replaces `noindex()`, which has been deprecated.
* `wp_robots_no_robots()` replaces `wp_no_robots()`, which has been deprecated.
* `wp_robots_sensitive_page()` replaces `wp_sensitive_page_meta()`, which has been deprecated. Its rendering of the `referrer` meta tag has been moved to another new function `wp_strict_cross_origin_referrer()`.
Migration to the new functions is straightforward. For example, a call to `add_action( 'wp_head', 'wp_no_robots' )` should be replaced with `add_filter( 'wp_robots', 'wp_robots_no_robots' )`.
Plugins and themes that render their own `robots` meta tags are encouraged to switch to rely on the `wp_robots` filter in order to use the central management layer now provided by WordPress core.
Props adamsilverstein, flixos90, timothyblynjacobs, westonruter.
See #51511.
Built from https://develop.svn.wordpress.org/trunk@49992
git-svn-id: http://core.svn.wordpress.org/trunk@49693 1a063a9b-81f0-0310-95a4-ce76da25c4cd
2021-01-20 20:37:00 -05:00
* discouraged in favor of robots meta HTML tag via wp_robots_no_robots ()
* filter callback .
2008-06-15 05:38:32 -04:00
*/
2006-05-22 18:06:06 -04:00
function do_robots () {
2007-10-11 01:46:57 -04:00
header ( 'Content-Type: text/plain; charset=utf-8' );
2007-03-27 12:44:36 -04:00
2014-04-13 20:20:14 -04:00
/**
* Fires when displaying the robots . txt file .
*
* @ since 2.1 . 0
*/
2007-10-11 01:46:57 -04:00
do_action ( 'do_robotstxt' );
2007-03-27 12:44:36 -04:00
2011-09-29 17:47:04 -04:00
$output = " User-agent: * \n " ;
2010-03-30 11:48:52 -04:00
$public = get_option ( 'blog_public' );
2019-09-01 22:27:55 -04:00
$site_url = parse_url ( site_url () );
$path = ( ! empty ( $site_url [ 'path' ] ) ) ? $site_url [ 'path' ] : '' ;
$output .= " Disallow: $path /wp-admin/ \n " ;
$output .= " Allow: $path /wp-admin/admin-ajax.php \n " ;
2010-03-30 11:48:52 -04:00
2014-04-13 20:20:14 -04:00
/**
2016-05-22 14:36:27 -04:00
* Filters the robots . txt output .
2014-04-13 20:20:14 -04:00
*
* @ since 3.0 . 0
*
2019-08-26 20:17:56 -04:00
* @ param string $output The robots . txt output .
2014-04-13 20:20:14 -04:00
* @ param bool $public Whether the site is considered " public " .
*/
echo apply_filters ( 'robots_txt' , $output , $public );
2006-05-22 18:06:06 -04:00
}
Bootstrap/Load: Make handling the `/favicon.ico` requests more flexible.
Previously, `wp_favicon_request()` was introduced in [13205] to avoid a performance hit of serving a full 404 page on every favicon request.
While working as intended, that implementation did not provide a way for theme or plugin authors to manage the behavior of favicon requests.
This changeset implements the following logic (only applied if WordPress is installed in the root directory):
* If there is a Site Icon set in Customizer, redirect `/favicon.ico` requests to that icon.
* Otherwise, use the WordPress logo as a default icon.
* If a physical `/favicon.ico` file exists, do nothing, let the server handle the request.
Handling `/favicon.ico` is now more consistent with handling `/robots.txt` requests.
New functions and hooks:
* Introduce `is_favicon()` conditional tag to complement `is_robots()`.
* Introduce `do_favicon` action to complement `do_robots` and use it in template loader.
* Introduce `do_favicon()` function, hooked to the above action by default, to complement `do_robots()`.
* Introduce `do_faviconico` action to complement `do_robotstxt`, for plugins to override the default behavior.
* Mark `wp_favicon_request()` as deprecated in favor of `do_favicon()`.
Props jonoaldersonwp, birgire, joostdevalk, mukesh27, SergeyBiryukov.
Fixes #47398.
Built from https://develop.svn.wordpress.org/trunk@47018
git-svn-id: http://core.svn.wordpress.org/trunk@46818 1a063a9b-81f0-0310-95a4-ce76da25c4cd
2019-12-28 16:20:04 -05:00
/**
2022-08-12 05:53:11 -04:00
* Displays the favicon . ico file content .
Bootstrap/Load: Make handling the `/favicon.ico` requests more flexible.
Previously, `wp_favicon_request()` was introduced in [13205] to avoid a performance hit of serving a full 404 page on every favicon request.
While working as intended, that implementation did not provide a way for theme or plugin authors to manage the behavior of favicon requests.
This changeset implements the following logic (only applied if WordPress is installed in the root directory):
* If there is a Site Icon set in Customizer, redirect `/favicon.ico` requests to that icon.
* Otherwise, use the WordPress logo as a default icon.
* If a physical `/favicon.ico` file exists, do nothing, let the server handle the request.
Handling `/favicon.ico` is now more consistent with handling `/robots.txt` requests.
New functions and hooks:
* Introduce `is_favicon()` conditional tag to complement `is_robots()`.
* Introduce `do_favicon` action to complement `do_robots` and use it in template loader.
* Introduce `do_favicon()` function, hooked to the above action by default, to complement `do_robots()`.
* Introduce `do_faviconico` action to complement `do_robotstxt`, for plugins to override the default behavior.
* Mark `wp_favicon_request()` as deprecated in favor of `do_favicon()`.
Props jonoaldersonwp, birgire, joostdevalk, mukesh27, SergeyBiryukov.
Fixes #47398.
Built from https://develop.svn.wordpress.org/trunk@47018
git-svn-id: http://core.svn.wordpress.org/trunk@46818 1a063a9b-81f0-0310-95a4-ce76da25c4cd
2019-12-28 16:20:04 -05:00
*
* @ since 5.4 . 0
*/
function do_favicon () {
/**
* Fires when serving the favicon . ico file .
*
* @ since 5.4 . 0
*/
do_action ( 'do_faviconico' );
2020-05-21 05:10:12 -04:00
wp_redirect ( get_site_icon_url ( 32 , includes_url ( 'images/w-logo-blue-white-bg.png' ) ) );
Bootstrap/Load: Make handling the `/favicon.ico` requests more flexible.
Previously, `wp_favicon_request()` was introduced in [13205] to avoid a performance hit of serving a full 404 page on every favicon request.
While working as intended, that implementation did not provide a way for theme or plugin authors to manage the behavior of favicon requests.
This changeset implements the following logic (only applied if WordPress is installed in the root directory):
* If there is a Site Icon set in Customizer, redirect `/favicon.ico` requests to that icon.
* Otherwise, use the WordPress logo as a default icon.
* If a physical `/favicon.ico` file exists, do nothing, let the server handle the request.
Handling `/favicon.ico` is now more consistent with handling `/robots.txt` requests.
New functions and hooks:
* Introduce `is_favicon()` conditional tag to complement `is_robots()`.
* Introduce `do_favicon` action to complement `do_robots` and use it in template loader.
* Introduce `do_favicon()` function, hooked to the above action by default, to complement `do_robots()`.
* Introduce `do_faviconico` action to complement `do_robotstxt`, for plugins to override the default behavior.
* Mark `wp_favicon_request()` as deprecated in favor of `do_favicon()`.
Props jonoaldersonwp, birgire, joostdevalk, mukesh27, SergeyBiryukov.
Fixes #47398.
Built from https://develop.svn.wordpress.org/trunk@47018
git-svn-id: http://core.svn.wordpress.org/trunk@46818 1a063a9b-81f0-0310-95a4-ce76da25c4cd
2019-12-28 16:20:04 -05:00
exit ;
}
2008-08-09 00:51:51 -04:00
/**
2018-02-13 11:54:31 -05:00
* Determines whether WordPress is already installed .
2008-08-09 00:51:51 -04:00
*
2014-06-30 21:44:15 -04:00
* The cache will be checked first . If you have a cache plugin , which saves
* the cache values , then this will work . If you use the default WordPress
* cache , and the database goes away , then you might have problems .
2008-08-09 00:51:51 -04:00
*
2014-06-30 21:44:15 -04:00
* Checks for the 'siteurl' option for whether WordPress is installed .
2018-02-18 21:13:32 -05:00
*
2018-02-13 11:54:31 -05:00
* For more information on this and similar theme functions , check out
2018-02-18 21:13:32 -05:00
* the { @ link https :// developer . wordpress . org / themes / basics / conditional - tags /
2018-02-13 11:54:31 -05:00
* Conditional Tags } article in the Theme Developer Handbook .
2008-08-09 00:51:51 -04:00
*
* @ since 2.1 . 0
*
2014-10-31 13:56:22 -04:00
* @ global wpdb $wpdb WordPress database abstraction object .
2014-06-30 21:44:15 -04:00
*
2016-01-27 22:51:26 -05:00
* @ return bool Whether the site is already installed .
2008-08-09 00:51:51 -04:00
*/
2006-03-31 03:07:39 -05:00
function is_blog_installed () {
2007-10-14 05:38:12 -04:00
global $wpdb ;
2007-10-13 14:39:28 -04:00
2014-06-30 21:44:15 -04:00
/*
* Check cache first . If options table goes away and we have true
* cached , oh well .
*/
2017-11-30 18:11:00 -05:00
if ( wp_cache_get ( 'is_blog_installed' ) ) {
2007-10-14 03:57:56 -04:00
return true ;
2017-11-30 18:11:00 -05:00
}
2007-10-13 14:39:28 -04:00
2008-03-12 18:41:43 -04:00
$suppress = $wpdb -> suppress_errors ();
Use `wp_installing()` instead of `WP_INSTALLING` constant.
The `WP_INSTALLING` constant is a flag that WordPress sets in a number of
places, telling the system that options should be fetched directly from the
database instead of from the cache, that WP should not ping wordpress.org for
updates, that the normal "not installed" checks should be bypassed, and so on.
A constant is generally necessary for this purpose, because the flag is
typically set before the WP bootstrap, meaning that WP functions are not yet
available. However, it is possible - notably, during `wpmu_create_blog()` -
for the "installing" flag to be set after WP has already loaded. In these
cases, `WP_INSTALLING` would be set for the remainder of the process, since
there's no way to change a constant once it's defined. This, in turn, polluted
later function calls that ought to have been outside the scope of site
creation, particularly the non-caching of option data. The problem was
particularly evident in the case of the automated tests, where `WP_INSTALLING`
was set the first time a site was created, and remained set for the rest of the
suite.
The new `wp_installing()` function allows developers to fetch the current
installation status (when called without any arguments) or to set the
installation status (when called with a boolean `true` or `false`). Use of
the `WP_INSTALLING` constant is still supported; `wp_installing()` will default
to `true` if the constant is defined during the bootstrap.
Props boonebgorges, jeremyfelt.
See #31130.
Built from https://develop.svn.wordpress.org/trunk@34828
git-svn-id: http://core.svn.wordpress.org/trunk@34793 1a063a9b-81f0-0310-95a4-ce76da25c4cd
2015-10-05 11:06:28 -04:00
if ( ! wp_installing () ) {
2010-02-05 12:59:24 -05:00
$alloptions = wp_load_alloptions ();
}
2020-01-28 19:45:18 -05:00
// If siteurl is not set to autoload, check it specifically.
2017-11-30 18:11:00 -05:00
if ( ! isset ( $alloptions [ 'siteurl' ] ) ) {
2009-04-16 18:00:39 -04:00
$installed = $wpdb -> get_var ( " SELECT option_value FROM $wpdb->options WHERE option_name = 'siteurl' " );
2017-11-30 18:11:00 -05:00
} else {
2009-04-16 18:00:39 -04:00
$installed = $alloptions [ 'siteurl' ];
2017-11-30 18:11:00 -05:00
}
2009-04-16 21:43:53 -04:00
$wpdb -> suppress_errors ( $suppress );
2007-03-23 13:45:40 -04:00
2017-11-30 18:11:00 -05:00
$installed = ! empty ( $installed );
2009-04-16 21:43:53 -04:00
wp_cache_set ( 'is_blog_installed' , $installed );
2007-10-14 03:57:56 -04:00
2017-11-30 18:11:00 -05:00
if ( $installed ) {
2009-09-06 14:46:27 -04:00
return true ;
2017-11-30 18:11:00 -05:00
}
2009-09-06 14:46:27 -04:00
2011-10-21 18:16:33 -04:00
// If visiting repair.php, return true and let it take over.
2017-11-30 18:11:00 -05:00
if ( defined ( 'WP_REPAIRING' ) ) {
2011-10-21 18:16:33 -04:00
return true ;
2017-11-30 18:11:00 -05:00
}
2011-10-21 18:16:33 -04:00
2009-09-06 14:46:27 -04:00
$suppress = $wpdb -> suppress_errors ();
2014-06-30 21:44:15 -04:00
/*
2017-08-22 07:52:48 -04:00
* Loop over the WP tables . If none exist , then scratch installation is allowed .
2014-06-30 21:44:15 -04:00
* If one or more exist , suggest table repair since we got here because the
* options table could not be accessed .
*/
2011-10-21 18:16:33 -04:00
$wp_tables = $wpdb -> tables ();
2010-02-19 14:57:03 -05:00
foreach ( $wp_tables as $table ) {
2020-11-02 13:04:07 -05:00
// The existence of custom user tables shouldn't suggest an unwise state or prevent a clean installation.
2017-11-30 18:11:00 -05:00
if ( defined ( 'CUSTOM_USER_TABLE' ) && CUSTOM_USER_TABLE == $table ) {
2011-10-21 18:16:33 -04:00
continue ;
2017-11-30 18:11:00 -05:00
}
if ( defined ( 'CUSTOM_USER_META_TABLE' ) && CUSTOM_USER_META_TABLE == $table ) {
2011-10-21 18:16:33 -04:00
continue ;
2017-11-30 18:11:00 -05:00
}
2010-03-03 02:27:18 -05:00
2020-10-29 14:06:13 -04:00
$described_table = $wpdb -> get_results ( " DESCRIBE $table ; " );
Upgrade/Install: During the install process, add additional checking for exising tables.
If reinstalling WordPress, there is a condition where tables would exist in the database. Ensures that when that is the case, the install process can carry along without issue.
Fixes #51676.
Props xknown, garubi, mukesh27, desrosj, johnbillion, metalandcoffee, davidbaumwald, whyisjake.
Built from https://develop.svn.wordpress.org/trunk@49452
git-svn-id: http://core.svn.wordpress.org/trunk@49211 1a063a9b-81f0-0310-95a4-ce76da25c4cd
2020-10-30 13:52:07 -04:00
if (
( ! $described_table && empty ( $wpdb -> last_error ) ) ||
( is_array ( $described_table ) && 0 === count ( $described_table ) )
) {
2011-10-21 18:16:33 -04:00
continue ;
2017-11-30 18:11:00 -05:00
}
2011-10-21 18:16:33 -04:00
2020-11-02 13:04:07 -05:00
// One or more tables exist. This is not good.
2011-10-21 18:16:33 -04:00
2012-01-26 15:34:27 -05:00
wp_load_translations_early ();
2011-10-21 18:16:33 -04:00
// Die with a DB error.
2016-08-23 19:48:28 -04:00
$wpdb -> error = sprintf (
2019-09-02 20:41:05 -04:00
/* translators: %s: Database repair URL. */
2016-08-23 19:48:28 -04:00
__ ( 'One or more database tables are unavailable. The database may need to be <a href="%s">repaired</a>.' ),
'maint/repair.php?referrer=is_blog_installed'
);
2011-10-21 18:16:33 -04:00
dead_db ();
2009-09-06 14:46:27 -04:00
}
2011-10-21 18:16:33 -04:00
$wpdb -> suppress_errors ( $suppress );
2009-09-06 14:46:27 -04:00
wp_cache_set ( 'is_blog_installed' , false );
return false ;
2006-03-31 03:07:39 -05:00
}
2006-04-18 23:03:27 -04:00
2008-08-09 00:51:51 -04:00
/**
2022-08-12 05:53:11 -04:00
* Retrieves URL with nonce added to URL query .
2008-08-09 00:51:51 -04:00
*
* @ since 2.0 . 4
*
2014-11-30 18:24:25 -05:00
* @ param string $actionurl URL to add nonce action .
* @ param int | string $action Optional . Nonce action name . Default - 1.
* @ param string $name Optional . Nonce name . Default '_wpnonce' .
2014-02-02 05:53:11 -05:00
* @ return string Escaped URL with nonce action added .
2008-08-09 00:51:51 -04:00
*/
2013-02-28 13:08:53 -05:00
function wp_nonce_url ( $actionurl , $action = - 1 , $name = '_wpnonce' ) {
2007-10-11 01:46:57 -04:00
$actionurl = str_replace ( '&' , '&' , $actionurl );
2013-03-07 01:57:56 -05:00
return esc_html ( add_query_arg ( $name , wp_create_nonce ( $action ), $actionurl ) );
2006-05-02 18:08:34 -04:00
}
2008-08-10 12:45:50 -04:00
/**
2022-08-12 05:53:11 -04:00
* Retrieves or display nonce hidden field for forms .
2008-08-10 12:45:50 -04:00
*
* The nonce field is used to validate that the contents of the form came from
* the location on the current site and not somewhere else . The nonce does not
* offer absolute protection , but should protect against most cases . It is very
* important to use nonce field in forms .
*
* The $action and $name are optional , but if you want to have better security ,
* it is strongly suggested to set those two parameters . It is easier to just
* call the function without any parameters , because validation of the nonce
* doesn ' t require any parameters , but since crackers know what the default is
* it won ' t be difficult for them to find a way around your nonce and cause
* damage .
*
* The input name will be whatever $name value you gave . The input value will be
* the nonce creation value .
*
* @ since 2.0 . 4
*
2014-11-30 18:24:25 -05:00
* @ param int | string $action Optional . Action name . Default - 1.
* @ param string $name Optional . Nonce name . Default '_wpnonce' .
* @ param bool $referer Optional . Whether to set the referer field for validation . Default true .
Code Modernization: Rename parameters that use reserved keywords in `wp-includes/functions.php`.
While using reserved PHP keywords as parameter name labels is allowed, in the context of function calls using named parameters in PHP 8.0+, this will easily lead to confusion. To avoid that, it is recommended not to use reserved keywords as function parameter names.
This commit:
* Renames the `$echo` parameter to `$display` in:
* `wp_nonce_field()`
* `wp_referer_field()`
* `wp_original_referer_field()`
* Renames the `$string` parameter to `$input_string` in
* `_wp_json_convert_string()`
* `_wp_to_kebab_case()`
* Renames the `$list` parameter to `$input_list` in:
* `wp_parse_list()`
* `wp_parse_id_list()`
* `wp_parse_slug_list()`
* `wp_filter_object_list()`
* `wp_list_filter()`
* `wp_list_pluck()`
* `wp_list_sort()`
* Renames the `$array` parameter to `$input_array` in:
* `add_magic_quotes()`
* `wp_array_slice_assoc()`
* `_wp_array_get()`
* `_wp_array_set()`
* Renames the `$function` parameter to `$function_name` in:
* `_deprecated_function()`
* `_deprecated_argument()`
* `_doing_it_wrong()`
* Renames the `$class` parameter to `$class_name` in `_deprecated_constructor()`.
* Renames the `$default` parameter to `$default_value` in `apache_mod_loaded()`.
* Renames the `$var` parameter to `$value` in `wp_validate_boolean()`.
* Amends the `$input` parameter in `wp_parse_str()` for consistency.
Follow-up to [52946], [52996], [52997], [52998], [53003], [53014], [53029], [53039], [53116], [53117], [53137], [53174], [53184], [53185], [53192], [53193], [53198], [53203], [53207], [53215], [53216], [53220], [53230], [53232], [53236], [53239], [53240], [53242], [53243], [53245], [53246], [53257], [53269], [53270], [53271], [53272], [53273], [53274], [53275], [53276], [53277], [53281], [53283], [53284], [53285], [53287], [53364], [53365], [54927].
Props jrf, aristath, poena, justinahinon, SergeyBiryukov.
See #56788.
Built from https://develop.svn.wordpress.org/trunk@54929
git-svn-id: http://core.svn.wordpress.org/trunk@54481 1a063a9b-81f0-0310-95a4-ce76da25c4cd
2022-12-03 10:07:14 -05:00
* @ param bool $display Optional . Whether to display or return hidden form field . Default true .
2014-06-30 21:44:15 -04:00
* @ return string Nonce field HTML markup .
2008-08-10 12:45:50 -04:00
*/
Code Modernization: Rename parameters that use reserved keywords in `wp-includes/functions.php`.
While using reserved PHP keywords as parameter name labels is allowed, in the context of function calls using named parameters in PHP 8.0+, this will easily lead to confusion. To avoid that, it is recommended not to use reserved keywords as function parameter names.
This commit:
* Renames the `$echo` parameter to `$display` in:
* `wp_nonce_field()`
* `wp_referer_field()`
* `wp_original_referer_field()`
* Renames the `$string` parameter to `$input_string` in
* `_wp_json_convert_string()`
* `_wp_to_kebab_case()`
* Renames the `$list` parameter to `$input_list` in:
* `wp_parse_list()`
* `wp_parse_id_list()`
* `wp_parse_slug_list()`
* `wp_filter_object_list()`
* `wp_list_filter()`
* `wp_list_pluck()`
* `wp_list_sort()`
* Renames the `$array` parameter to `$input_array` in:
* `add_magic_quotes()`
* `wp_array_slice_assoc()`
* `_wp_array_get()`
* `_wp_array_set()`
* Renames the `$function` parameter to `$function_name` in:
* `_deprecated_function()`
* `_deprecated_argument()`
* `_doing_it_wrong()`
* Renames the `$class` parameter to `$class_name` in `_deprecated_constructor()`.
* Renames the `$default` parameter to `$default_value` in `apache_mod_loaded()`.
* Renames the `$var` parameter to `$value` in `wp_validate_boolean()`.
* Amends the `$input` parameter in `wp_parse_str()` for consistency.
Follow-up to [52946], [52996], [52997], [52998], [53003], [53014], [53029], [53039], [53116], [53117], [53137], [53174], [53184], [53185], [53192], [53193], [53198], [53203], [53207], [53215], [53216], [53220], [53230], [53232], [53236], [53239], [53240], [53242], [53243], [53245], [53246], [53257], [53269], [53270], [53271], [53272], [53273], [53274], [53275], [53276], [53277], [53281], [53283], [53284], [53285], [53287], [53364], [53365], [54927].
Props jrf, aristath, poena, justinahinon, SergeyBiryukov.
See #56788.
Built from https://develop.svn.wordpress.org/trunk@54929
git-svn-id: http://core.svn.wordpress.org/trunk@54481 1a063a9b-81f0-0310-95a4-ce76da25c4cd
2022-12-03 10:07:14 -05:00
function wp_nonce_field ( $action = - 1 , $name = '_wpnonce' , $referer = true , $display = true ) {
2017-11-30 18:11:00 -05:00
$name = esc_attr ( $name );
2008-03-15 18:44:34 -04:00
$nonce_field = '<input type="hidden" id="' . $name . '" name="' . $name . '" value="' . wp_create_nonce ( $action ) . '" />' ;
2008-08-09 01:36:14 -04:00
2017-11-30 18:11:00 -05:00
if ( $referer ) {
2011-06-03 14:23:41 -04:00
$nonce_field .= wp_referer_field ( false );
2017-11-30 18:11:00 -05:00
}
2011-06-03 14:23:41 -04:00
Code Modernization: Rename parameters that use reserved keywords in `wp-includes/functions.php`.
While using reserved PHP keywords as parameter name labels is allowed, in the context of function calls using named parameters in PHP 8.0+, this will easily lead to confusion. To avoid that, it is recommended not to use reserved keywords as function parameter names.
This commit:
* Renames the `$echo` parameter to `$display` in:
* `wp_nonce_field()`
* `wp_referer_field()`
* `wp_original_referer_field()`
* Renames the `$string` parameter to `$input_string` in
* `_wp_json_convert_string()`
* `_wp_to_kebab_case()`
* Renames the `$list` parameter to `$input_list` in:
* `wp_parse_list()`
* `wp_parse_id_list()`
* `wp_parse_slug_list()`
* `wp_filter_object_list()`
* `wp_list_filter()`
* `wp_list_pluck()`
* `wp_list_sort()`
* Renames the `$array` parameter to `$input_array` in:
* `add_magic_quotes()`
* `wp_array_slice_assoc()`
* `_wp_array_get()`
* `_wp_array_set()`
* Renames the `$function` parameter to `$function_name` in:
* `_deprecated_function()`
* `_deprecated_argument()`
* `_doing_it_wrong()`
* Renames the `$class` parameter to `$class_name` in `_deprecated_constructor()`.
* Renames the `$default` parameter to `$default_value` in `apache_mod_loaded()`.
* Renames the `$var` parameter to `$value` in `wp_validate_boolean()`.
* Amends the `$input` parameter in `wp_parse_str()` for consistency.
Follow-up to [52946], [52996], [52997], [52998], [53003], [53014], [53029], [53039], [53116], [53117], [53137], [53174], [53184], [53185], [53192], [53193], [53198], [53203], [53207], [53215], [53216], [53220], [53230], [53232], [53236], [53239], [53240], [53242], [53243], [53245], [53246], [53257], [53269], [53270], [53271], [53272], [53273], [53274], [53275], [53276], [53277], [53281], [53283], [53284], [53285], [53287], [53364], [53365], [54927].
Props jrf, aristath, poena, justinahinon, SergeyBiryukov.
See #56788.
Built from https://develop.svn.wordpress.org/trunk@54929
git-svn-id: http://core.svn.wordpress.org/trunk@54481 1a063a9b-81f0-0310-95a4-ce76da25c4cd
2022-12-03 10:07:14 -05:00
if ( $display ) {
2011-06-03 14:23:41 -04:00
echo $nonce_field ;
2017-11-30 18:11:00 -05:00
}
2008-08-09 01:36:14 -04:00
2008-03-15 18:44:34 -04:00
return $nonce_field ;
2006-06-24 01:38:37 -04:00
}
2008-08-10 12:45:50 -04:00
/**
2022-08-12 05:53:11 -04:00
* Retrieves or displays referer hidden field for forms .
2008-08-10 12:45:50 -04:00
*
* The referer link is the current Request URI from the server super global . The
* input name is '_wp_http_referer' , in case you wanted to check manually .
*
* @ since 2.0 . 4
*
Code Modernization: Rename parameters that use reserved keywords in `wp-includes/functions.php`.
While using reserved PHP keywords as parameter name labels is allowed, in the context of function calls using named parameters in PHP 8.0+, this will easily lead to confusion. To avoid that, it is recommended not to use reserved keywords as function parameter names.
This commit:
* Renames the `$echo` parameter to `$display` in:
* `wp_nonce_field()`
* `wp_referer_field()`
* `wp_original_referer_field()`
* Renames the `$string` parameter to `$input_string` in
* `_wp_json_convert_string()`
* `_wp_to_kebab_case()`
* Renames the `$list` parameter to `$input_list` in:
* `wp_parse_list()`
* `wp_parse_id_list()`
* `wp_parse_slug_list()`
* `wp_filter_object_list()`
* `wp_list_filter()`
* `wp_list_pluck()`
* `wp_list_sort()`
* Renames the `$array` parameter to `$input_array` in:
* `add_magic_quotes()`
* `wp_array_slice_assoc()`
* `_wp_array_get()`
* `_wp_array_set()`
* Renames the `$function` parameter to `$function_name` in:
* `_deprecated_function()`
* `_deprecated_argument()`
* `_doing_it_wrong()`
* Renames the `$class` parameter to `$class_name` in `_deprecated_constructor()`.
* Renames the `$default` parameter to `$default_value` in `apache_mod_loaded()`.
* Renames the `$var` parameter to `$value` in `wp_validate_boolean()`.
* Amends the `$input` parameter in `wp_parse_str()` for consistency.
Follow-up to [52946], [52996], [52997], [52998], [53003], [53014], [53029], [53039], [53116], [53117], [53137], [53174], [53184], [53185], [53192], [53193], [53198], [53203], [53207], [53215], [53216], [53220], [53230], [53232], [53236], [53239], [53240], [53242], [53243], [53245], [53246], [53257], [53269], [53270], [53271], [53272], [53273], [53274], [53275], [53276], [53277], [53281], [53283], [53284], [53285], [53287], [53364], [53365], [54927].
Props jrf, aristath, poena, justinahinon, SergeyBiryukov.
See #56788.
Built from https://develop.svn.wordpress.org/trunk@54929
git-svn-id: http://core.svn.wordpress.org/trunk@54481 1a063a9b-81f0-0310-95a4-ce76da25c4cd
2022-12-03 10:07:14 -05:00
* @ param bool $display Optional . Whether to echo or return the referer field . Default true .
2014-06-30 21:44:15 -04:00
* @ return string Referer field HTML markup .
2008-08-10 12:45:50 -04:00
*/
Code Modernization: Rename parameters that use reserved keywords in `wp-includes/functions.php`.
While using reserved PHP keywords as parameter name labels is allowed, in the context of function calls using named parameters in PHP 8.0+, this will easily lead to confusion. To avoid that, it is recommended not to use reserved keywords as function parameter names.
This commit:
* Renames the `$echo` parameter to `$display` in:
* `wp_nonce_field()`
* `wp_referer_field()`
* `wp_original_referer_field()`
* Renames the `$string` parameter to `$input_string` in
* `_wp_json_convert_string()`
* `_wp_to_kebab_case()`
* Renames the `$list` parameter to `$input_list` in:
* `wp_parse_list()`
* `wp_parse_id_list()`
* `wp_parse_slug_list()`
* `wp_filter_object_list()`
* `wp_list_filter()`
* `wp_list_pluck()`
* `wp_list_sort()`
* Renames the `$array` parameter to `$input_array` in:
* `add_magic_quotes()`
* `wp_array_slice_assoc()`
* `_wp_array_get()`
* `_wp_array_set()`
* Renames the `$function` parameter to `$function_name` in:
* `_deprecated_function()`
* `_deprecated_argument()`
* `_doing_it_wrong()`
* Renames the `$class` parameter to `$class_name` in `_deprecated_constructor()`.
* Renames the `$default` parameter to `$default_value` in `apache_mod_loaded()`.
* Renames the `$var` parameter to `$value` in `wp_validate_boolean()`.
* Amends the `$input` parameter in `wp_parse_str()` for consistency.
Follow-up to [52946], [52996], [52997], [52998], [53003], [53014], [53029], [53039], [53116], [53117], [53137], [53174], [53184], [53185], [53192], [53193], [53198], [53203], [53207], [53215], [53216], [53220], [53230], [53232], [53236], [53239], [53240], [53242], [53243], [53245], [53246], [53257], [53269], [53270], [53271], [53272], [53273], [53274], [53275], [53276], [53277], [53281], [53283], [53284], [53285], [53287], [53364], [53365], [54927].
Props jrf, aristath, poena, justinahinon, SergeyBiryukov.
See #56788.
Built from https://develop.svn.wordpress.org/trunk@54929
git-svn-id: http://core.svn.wordpress.org/trunk@54481 1a063a9b-81f0-0310-95a4-ce76da25c4cd
2022-12-03 10:07:14 -05:00
function wp_referer_field ( $display = true ) {
General: Remove instances of `_wp_http_referer` from GET forms in the admin.
This changeset removes all instances of `_wp_http_referer` variable from the URL when creating a hidden input for `_wp_http_referer`. It prevents the hidden field from having an additional version of `_wp_http_referer` each time the form is submitted.
Props msolution, justinahinon, pbearne, mikeschroder, mukesh27, audrasjb, Clorith, chaion07, robinwpdeveloper, hztyfoon, davidbaumwald, costdev, adamsilverstein.
Fixes #54106.
Built from https://develop.svn.wordpress.org/trunk@54449
git-svn-id: http://core.svn.wordpress.org/trunk@54008 1a063a9b-81f0-0310-95a4-ce76da25c4cd
2022-10-10 14:59:11 -04:00
$request_url = remove_query_arg ( '_wp_http_referer' );
$referer_field = '<input type="hidden" name="_wp_http_referer" value="' . esc_url ( $request_url ) . '" />' ;
2008-03-15 18:44:34 -04:00
Code Modernization: Rename parameters that use reserved keywords in `wp-includes/functions.php`.
While using reserved PHP keywords as parameter name labels is allowed, in the context of function calls using named parameters in PHP 8.0+, this will easily lead to confusion. To avoid that, it is recommended not to use reserved keywords as function parameter names.
This commit:
* Renames the `$echo` parameter to `$display` in:
* `wp_nonce_field()`
* `wp_referer_field()`
* `wp_original_referer_field()`
* Renames the `$string` parameter to `$input_string` in
* `_wp_json_convert_string()`
* `_wp_to_kebab_case()`
* Renames the `$list` parameter to `$input_list` in:
* `wp_parse_list()`
* `wp_parse_id_list()`
* `wp_parse_slug_list()`
* `wp_filter_object_list()`
* `wp_list_filter()`
* `wp_list_pluck()`
* `wp_list_sort()`
* Renames the `$array` parameter to `$input_array` in:
* `add_magic_quotes()`
* `wp_array_slice_assoc()`
* `_wp_array_get()`
* `_wp_array_set()`
* Renames the `$function` parameter to `$function_name` in:
* `_deprecated_function()`
* `_deprecated_argument()`
* `_doing_it_wrong()`
* Renames the `$class` parameter to `$class_name` in `_deprecated_constructor()`.
* Renames the `$default` parameter to `$default_value` in `apache_mod_loaded()`.
* Renames the `$var` parameter to `$value` in `wp_validate_boolean()`.
* Amends the `$input` parameter in `wp_parse_str()` for consistency.
Follow-up to [52946], [52996], [52997], [52998], [53003], [53014], [53029], [53039], [53116], [53117], [53137], [53174], [53184], [53185], [53192], [53193], [53198], [53203], [53207], [53215], [53216], [53220], [53230], [53232], [53236], [53239], [53240], [53242], [53243], [53245], [53246], [53257], [53269], [53270], [53271], [53272], [53273], [53274], [53275], [53276], [53277], [53281], [53283], [53284], [53285], [53287], [53364], [53365], [54927].
Props jrf, aristath, poena, justinahinon, SergeyBiryukov.
See #56788.
Built from https://develop.svn.wordpress.org/trunk@54929
git-svn-id: http://core.svn.wordpress.org/trunk@54481 1a063a9b-81f0-0310-95a4-ce76da25c4cd
2022-12-03 10:07:14 -05:00
if ( $display ) {
2008-03-15 18:44:34 -04:00
echo $referer_field ;
2017-11-30 18:11:00 -05:00
}
2020-05-16 14:42:12 -04:00
2008-03-15 18:44:34 -04:00
return $referer_field ;
2006-06-24 01:38:37 -04:00
}
2008-08-10 12:45:50 -04:00
/**
2022-08-12 05:53:11 -04:00
* Retrieves or displays original referer hidden field for forms .
2008-08-10 12:45:50 -04:00
*
* The input name is '_wp_original_http_referer' and will be either the same
2014-06-30 21:44:15 -04:00
* value of wp_referer_field (), if that was posted already or it will be the
* current page , if it doesn ' t exist .
2008-08-10 12:45:50 -04:00
*
* @ since 2.0 . 4
*
Code Modernization: Rename parameters that use reserved keywords in `wp-includes/functions.php`.
While using reserved PHP keywords as parameter name labels is allowed, in the context of function calls using named parameters in PHP 8.0+, this will easily lead to confusion. To avoid that, it is recommended not to use reserved keywords as function parameter names.
This commit:
* Renames the `$echo` parameter to `$display` in:
* `wp_nonce_field()`
* `wp_referer_field()`
* `wp_original_referer_field()`
* Renames the `$string` parameter to `$input_string` in
* `_wp_json_convert_string()`
* `_wp_to_kebab_case()`
* Renames the `$list` parameter to `$input_list` in:
* `wp_parse_list()`
* `wp_parse_id_list()`
* `wp_parse_slug_list()`
* `wp_filter_object_list()`
* `wp_list_filter()`
* `wp_list_pluck()`
* `wp_list_sort()`
* Renames the `$array` parameter to `$input_array` in:
* `add_magic_quotes()`
* `wp_array_slice_assoc()`
* `_wp_array_get()`
* `_wp_array_set()`
* Renames the `$function` parameter to `$function_name` in:
* `_deprecated_function()`
* `_deprecated_argument()`
* `_doing_it_wrong()`
* Renames the `$class` parameter to `$class_name` in `_deprecated_constructor()`.
* Renames the `$default` parameter to `$default_value` in `apache_mod_loaded()`.
* Renames the `$var` parameter to `$value` in `wp_validate_boolean()`.
* Amends the `$input` parameter in `wp_parse_str()` for consistency.
Follow-up to [52946], [52996], [52997], [52998], [53003], [53014], [53029], [53039], [53116], [53117], [53137], [53174], [53184], [53185], [53192], [53193], [53198], [53203], [53207], [53215], [53216], [53220], [53230], [53232], [53236], [53239], [53240], [53242], [53243], [53245], [53246], [53257], [53269], [53270], [53271], [53272], [53273], [53274], [53275], [53276], [53277], [53281], [53283], [53284], [53285], [53287], [53364], [53365], [54927].
Props jrf, aristath, poena, justinahinon, SergeyBiryukov.
See #56788.
Built from https://develop.svn.wordpress.org/trunk@54929
git-svn-id: http://core.svn.wordpress.org/trunk@54481 1a063a9b-81f0-0310-95a4-ce76da25c4cd
2022-12-03 10:07:14 -05:00
* @ param bool $display Optional . Whether to echo the original http referer . Default true .
2014-06-30 21:44:15 -04:00
* @ param string $jump_back_to Optional . Can be 'previous' or page you want to jump back to .
* Default 'current' .
2008-08-10 12:45:50 -04:00
* @ return string Original referer field .
*/
Code Modernization: Rename parameters that use reserved keywords in `wp-includes/functions.php`.
While using reserved PHP keywords as parameter name labels is allowed, in the context of function calls using named parameters in PHP 8.0+, this will easily lead to confusion. To avoid that, it is recommended not to use reserved keywords as function parameter names.
This commit:
* Renames the `$echo` parameter to `$display` in:
* `wp_nonce_field()`
* `wp_referer_field()`
* `wp_original_referer_field()`
* Renames the `$string` parameter to `$input_string` in
* `_wp_json_convert_string()`
* `_wp_to_kebab_case()`
* Renames the `$list` parameter to `$input_list` in:
* `wp_parse_list()`
* `wp_parse_id_list()`
* `wp_parse_slug_list()`
* `wp_filter_object_list()`
* `wp_list_filter()`
* `wp_list_pluck()`
* `wp_list_sort()`
* Renames the `$array` parameter to `$input_array` in:
* `add_magic_quotes()`
* `wp_array_slice_assoc()`
* `_wp_array_get()`
* `_wp_array_set()`
* Renames the `$function` parameter to `$function_name` in:
* `_deprecated_function()`
* `_deprecated_argument()`
* `_doing_it_wrong()`
* Renames the `$class` parameter to `$class_name` in `_deprecated_constructor()`.
* Renames the `$default` parameter to `$default_value` in `apache_mod_loaded()`.
* Renames the `$var` parameter to `$value` in `wp_validate_boolean()`.
* Amends the `$input` parameter in `wp_parse_str()` for consistency.
Follow-up to [52946], [52996], [52997], [52998], [53003], [53014], [53029], [53039], [53116], [53117], [53137], [53174], [53184], [53185], [53192], [53193], [53198], [53203], [53207], [53215], [53216], [53220], [53230], [53232], [53236], [53239], [53240], [53242], [53243], [53245], [53246], [53257], [53269], [53270], [53271], [53272], [53273], [53274], [53275], [53276], [53277], [53281], [53283], [53284], [53285], [53287], [53364], [53365], [54927].
Props jrf, aristath, poena, justinahinon, SergeyBiryukov.
See #56788.
Built from https://develop.svn.wordpress.org/trunk@54929
git-svn-id: http://core.svn.wordpress.org/trunk@54481 1a063a9b-81f0-0310-95a4-ce76da25c4cd
2022-12-03 10:07:14 -05:00
function wp_original_referer_field ( $display = true , $jump_back_to = 'current' ) {
2019-07-02 19:42:58 -04:00
$ref = wp_get_original_referer ();
2020-05-16 14:42:12 -04:00
2019-07-02 19:42:58 -04:00
if ( ! $ref ) {
2020-05-16 14:42:12 -04:00
$ref = ( 'previous' === $jump_back_to ) ? wp_get_referer () : wp_unslash ( $_SERVER [ 'REQUEST_URI' ] );
2013-03-01 12:58:43 -05:00
}
2020-05-16 14:42:12 -04:00
2013-03-01 12:58:43 -05:00
$orig_referer_field = '<input type="hidden" name="_wp_original_http_referer" value="' . esc_attr ( $ref ) . '" />' ;
2020-05-16 14:42:12 -04:00
Code Modernization: Rename parameters that use reserved keywords in `wp-includes/functions.php`.
While using reserved PHP keywords as parameter name labels is allowed, in the context of function calls using named parameters in PHP 8.0+, this will easily lead to confusion. To avoid that, it is recommended not to use reserved keywords as function parameter names.
This commit:
* Renames the `$echo` parameter to `$display` in:
* `wp_nonce_field()`
* `wp_referer_field()`
* `wp_original_referer_field()`
* Renames the `$string` parameter to `$input_string` in
* `_wp_json_convert_string()`
* `_wp_to_kebab_case()`
* Renames the `$list` parameter to `$input_list` in:
* `wp_parse_list()`
* `wp_parse_id_list()`
* `wp_parse_slug_list()`
* `wp_filter_object_list()`
* `wp_list_filter()`
* `wp_list_pluck()`
* `wp_list_sort()`
* Renames the `$array` parameter to `$input_array` in:
* `add_magic_quotes()`
* `wp_array_slice_assoc()`
* `_wp_array_get()`
* `_wp_array_set()`
* Renames the `$function` parameter to `$function_name` in:
* `_deprecated_function()`
* `_deprecated_argument()`
* `_doing_it_wrong()`
* Renames the `$class` parameter to `$class_name` in `_deprecated_constructor()`.
* Renames the `$default` parameter to `$default_value` in `apache_mod_loaded()`.
* Renames the `$var` parameter to `$value` in `wp_validate_boolean()`.
* Amends the `$input` parameter in `wp_parse_str()` for consistency.
Follow-up to [52946], [52996], [52997], [52998], [53003], [53014], [53029], [53039], [53116], [53117], [53137], [53174], [53184], [53185], [53192], [53193], [53198], [53203], [53207], [53215], [53216], [53220], [53230], [53232], [53236], [53239], [53240], [53242], [53243], [53245], [53246], [53257], [53269], [53270], [53271], [53272], [53273], [53274], [53275], [53276], [53277], [53281], [53283], [53284], [53285], [53287], [53364], [53365], [54927].
Props jrf, aristath, poena, justinahinon, SergeyBiryukov.
See #56788.
Built from https://develop.svn.wordpress.org/trunk@54929
git-svn-id: http://core.svn.wordpress.org/trunk@54481 1a063a9b-81f0-0310-95a4-ce76da25c4cd
2022-12-03 10:07:14 -05:00
if ( $display ) {
2008-03-15 18:44:34 -04:00
echo $orig_referer_field ;
2017-11-30 18:11:00 -05:00
}
2020-05-16 14:42:12 -04:00
2008-03-15 18:44:34 -04:00
return $orig_referer_field ;
2006-06-24 01:38:37 -04:00
}
2008-08-10 12:45:50 -04:00
/**
2022-08-12 05:53:11 -04:00
* Retrieves referer from '_wp_http_referer' or HTTP referer .
2014-06-30 21:44:15 -04:00
*
* If it ' s the same as the current request URL , will return false .
2008-08-10 12:45:50 -04:00
*
* @ since 2.0 . 4
*
2020-01-11 13:32:05 -05:00
* @ return string | false Referer URL on success , false on failure .
2008-08-10 12:45:50 -04:00
*/
2006-06-24 01:38:37 -04:00
function wp_get_referer () {
2023-03-13 06:54:22 -04:00
// Return early if called before wp_validate_redirect() is defined.
2016-01-12 03:32:28 -05:00
if ( ! function_exists ( 'wp_validate_redirect' ) ) {
2013-09-12 09:33:09 -04:00
return false ;
2016-01-12 03:32:28 -05:00
}
$ref = wp_get_raw_referer ();
2008-03-20 23:31:12 -04:00
2023-03-13 06:54:22 -04:00
if ( $ref && wp_unslash ( $_SERVER [ 'REQUEST_URI' ] ) !== $ref
&& home_url () . wp_unslash ( $_SERVER [ 'REQUEST_URI' ] ) !== $ref
) {
2013-09-10 14:07:10 -04:00
return wp_validate_redirect ( $ref , false );
2016-01-09 09:36:26 -05:00
}
2006-06-24 01:38:37 -04:00
return false ;
}
2016-01-12 03:32:28 -05:00
/**
2023-06-29 19:27:23 -04:00
* Retrieves unvalidated referer from the '_wp_http_referer' URL query variable or the HTTP referer .
*
* If the value of the '_wp_http_referer' URL query variable is not a string then it will be ignored .
2016-01-12 03:32:28 -05:00
*
2016-05-02 00:00:28 -04:00
* Do not use for redirects , use wp_get_referer () instead .
2016-01-12 03:32:28 -05:00
*
* @ since 4.5 . 0
*
2016-02-07 03:09:25 -05:00
* @ return string | false Referer URL on success , false on failure .
2016-01-12 03:32:28 -05:00
*/
function wp_get_raw_referer () {
2023-06-29 19:27:23 -04:00
if ( ! empty ( $_REQUEST [ '_wp_http_referer' ] ) && is_string ( $_REQUEST [ '_wp_http_referer' ] ) ) {
2016-01-12 03:32:28 -05:00
return wp_unslash ( $_REQUEST [ '_wp_http_referer' ] );
2017-11-30 18:11:00 -05:00
} elseif ( ! empty ( $_SERVER [ 'HTTP_REFERER' ] ) ) {
2016-01-12 03:32:28 -05:00
return wp_unslash ( $_SERVER [ 'HTTP_REFERER' ] );
}
return false ;
}
2008-08-10 12:45:50 -04:00
/**
2022-08-12 05:53:11 -04:00
* Retrieves original referer that was posted , if it exists .
2008-08-10 12:45:50 -04:00
*
* @ since 2.0 . 4
*
2020-06-16 17:24:07 -04:00
* @ return string | false Original referer URL on success , false on failure .
2008-08-10 12:45:50 -04:00
*/
2006-06-24 01:38:37 -04:00
function wp_get_original_referer () {
2023-03-13 06:54:22 -04:00
// Return early if called before wp_validate_redirect() is defined.
if ( ! function_exists ( 'wp_validate_redirect' ) ) {
return false ;
}
if ( ! empty ( $_REQUEST [ '_wp_original_http_referer' ] ) ) {
2013-09-10 14:07:10 -04:00
return wp_validate_redirect ( wp_unslash ( $_REQUEST [ '_wp_original_http_referer' ] ), false );
2017-11-30 18:11:00 -05:00
}
2020-06-16 17:24:07 -04:00
2006-06-24 01:38:37 -04:00
return false ;
2006-05-02 18:08:34 -04:00
}
2008-08-10 12:45:50 -04:00
/**
* Recursive directory creation based on full path .
*
* Will attempt to set permissions on folders .
*
* @ since 2.0 . 1
*
* @ param string $target Full path to attempt to create .
2010-02-24 15:13:23 -05:00
* @ return bool Whether the path was created . True if path already exists .
2008-08-10 12:45:50 -04:00
*/
2007-10-11 01:46:57 -04:00
function wp_mkdir_p ( $target ) {
2012-10-01 16:59:06 -04:00
$wrapper = null ;
2014-06-30 21:44:15 -04:00
// Strip the protocol.
2015-06-16 16:01:25 -04:00
if ( wp_is_stream ( $target ) ) {
2012-10-01 16:59:06 -04:00
list ( $wrapper , $target ) = explode ( '://' , $target , 2 );
}
2014-06-30 21:44:15 -04:00
// From php.net/mkdir user contributed notes.
2008-03-21 14:27:56 -04:00
$target = str_replace ( '//' , '/' , $target );
2010-01-16 21:44:47 -05:00
2014-06-30 21:44:15 -04:00
// Put the wrapper back on the target.
2020-02-09 11:55:09 -05:00
if ( null !== $wrapper ) {
2012-10-01 16:59:06 -04:00
$target = $wrapper . '://' . $target ;
}
2014-06-30 21:44:15 -04:00
/*
* Safe mode fails with a trailing slash under certain PHP versions .
* Use rtrim () instead of untrailingslashit to avoid formatting . php dependency .
*/
2017-11-30 18:11:00 -05:00
$target = rtrim ( $target , '/' );
if ( empty ( $target ) ) {
2010-01-16 21:44:47 -05:00
$target = '/' ;
2017-11-30 18:11:00 -05:00
}
2010-01-16 21:44:47 -05:00
2017-11-30 18:11:00 -05:00
if ( file_exists ( $target ) ) {
2007-10-11 01:46:57 -04:00
return @ is_dir ( $target );
2017-11-30 18:11:00 -05:00
}
2006-06-07 19:17:59 -04:00
2019-10-14 11:31:04 -04:00
// Do not allow path traversals.
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 10:36:26 -04:00
if ( str_contains ( $target , '../' ) || str_contains ( $target , '..' . DIRECTORY_SEPARATOR ) ) {
2019-10-14 11:31:04 -04:00
return false ;
}
2013-08-16 23:09:11 -04:00
// We need to find the permissions of the parent folder that exists and inherit that.
$target_parent = dirname ( $target );
2020-05-16 14:42:12 -04:00
while ( '.' !== $target_parent && ! is_dir ( $target_parent ) && dirname ( $target_parent ) !== $target_parent ) {
2013-08-16 23:09:11 -04:00
$target_parent = dirname ( $target_parent );
}
// Get the permission bits.
2019-07-02 19:42:58 -04:00
$stat = @ stat ( $target_parent );
if ( $stat ) {
2013-08-16 23:09:11 -04:00
$dir_perms = $stat [ 'mode' ] & 0007777 ;
} else {
$dir_perms = 0777 ;
2006-06-07 19:17:59 -04:00
}
2013-08-16 23:09:11 -04:00
if ( @ mkdir ( $target , $dir_perms , true ) ) {
2013-11-27 21:20:10 -05:00
2014-06-30 21:44:15 -04:00
/*
* If a umask is set that modifies $dir_perms , we ' ll have to re - set
* the $dir_perms correctly with chmod ()
*/
2020-02-09 11:55:09 -05:00
if ( ( $dir_perms & ~ umask () ) != $dir_perms ) {
2013-11-27 21:20:10 -05:00
$folder_parts = explode ( '/' , substr ( $target , strlen ( $target_parent ) + 1 ) );
2015-02-26 00:48:24 -05:00
for ( $i = 1 , $c = count ( $folder_parts ); $i <= $c ; $i ++ ) {
2019-07-09 01:45:58 -04:00
chmod ( $target_parent . '/' . implode ( '/' , array_slice ( $folder_parts , 0 , $i ) ), $dir_perms );
2013-11-27 21:20:10 -05:00
}
}
2013-08-16 23:09:11 -04:00
return true ;
}
2008-12-09 13:03:31 -05:00
2006-06-07 19:17:59 -04:00
return false ;
}
2008-08-09 00:51:51 -04:00
/**
2022-08-12 05:53:11 -04:00
* Tests if a given filesystem path is absolute .
2014-06-30 21:44:15 -04:00
*
* For example , '/foo/bar' , or 'c:\windows' .
2008-08-09 00:51:51 -04:00
*
2008-08-10 12:45:50 -04:00
* @ since 2.5 . 0
2008-08-09 00:51:51 -04:00
*
2014-06-30 21:44:15 -04:00
* @ param string $path File path .
2008-08-09 00:51:51 -04:00
* @ return bool True if path is absolute , false is not absolute .
*/
2008-02-22 12:46:03 -05:00
function path_is_absolute ( $path ) {
2019-04-12 16:01:52 -04:00
/*
* Check to see if the path is a stream and check to see if its an actual
* path or file as realpath () does not support stream wrappers .
*/
if ( wp_is_stream ( $path ) && ( is_dir ( $path ) || is_file ( $path ) ) ) {
return true ;
}
2014-06-30 21:44:15 -04:00
/*
* This is definitive if true but fails if $path does not exist or contains
* a symbolic link .
*/
2022-08-26 14:59:13 -04:00
if ( realpath ( $path ) === $path ) {
2008-02-22 12:46:03 -05:00
return true ;
2017-11-30 18:11:00 -05:00
}
2008-02-22 12:46:03 -05:00
2022-08-26 14:59:13 -04:00
if ( strlen ( $path ) === 0 || '.' === $path [ 0 ] ) {
2008-02-22 12:46:03 -05:00
return false ;
2017-11-30 18:11:00 -05:00
}
2008-03-02 15:17:30 -05:00
2014-06-30 21:44:15 -04:00
// Windows allows absolute paths like this.
2017-11-30 18:11:00 -05:00
if ( preg_match ( '#^[a-zA-Z]:\\\\#' , $path ) ) {
2008-02-22 12:46:03 -05:00
return true ;
2017-11-30 18:11:00 -05:00
}
2008-02-22 12:46:03 -05:00
2014-06-30 21:44:15 -04:00
// A path starting with / or \ is absolute; anything else is relative.
2020-02-09 11:55:09 -05:00
return ( '/' === $path [ 0 ] || '\\' === $path [ 0 ] );
2008-02-22 12:46:03 -05:00
}
2008-08-09 00:51:51 -04:00
/**
2022-08-12 05:53:11 -04:00
* Joins two filesystem paths together .
2008-08-09 00:51:51 -04:00
*
2014-06-30 21:44:15 -04:00
* For example , 'give me $path relative to $base' . If the $path is absolute ,
* then it the full path is returned .
2008-08-09 00:51:51 -04:00
*
2008-08-10 12:45:50 -04:00
* @ since 2.5 . 0
2008-08-09 00:51:51 -04:00
*
2014-06-30 21:44:15 -04:00
* @ param string $base Base path .
* @ param string $path Path relative to $base .
2008-08-09 00:51:51 -04:00
* @ return string The path with the base or absolute path .
*/
2008-02-22 12:46:03 -05:00
function path_join ( $base , $path ) {
2017-11-30 18:11:00 -05:00
if ( path_is_absolute ( $path ) ) {
2008-02-22 12:46:03 -05:00
return $path ;
2017-11-30 18:11:00 -05:00
}
2008-03-02 15:17:30 -05:00
2022-06-02 11:31:08 -04:00
return rtrim ( $base , '/' ) . '/' . $path ;
2008-02-22 12:46:03 -05:00
}
2007-10-11 01:46:57 -04:00
2014-02-10 18:00:15 -05:00
/**
2022-08-12 05:53:11 -04:00
* Normalizes a filesystem path .
2014-02-10 18:00:15 -05:00
*
2015-09-13 21:59:25 -04:00
* On windows systems , replaces backslashes with forward slashes
* and forces upper - case drive letters .
2016-03-08 01:00:26 -05:00
* Allows for two leading slashes for Windows network shares , but
* ensures that all other duplicate slashes are reduced to a single .
2014-02-10 18:00:15 -05:00
*
* @ since 3.9 . 0
2015-09-13 21:59:25 -04:00
* @ since 4.4 . 0 Ensures upper - case drive letters on Windows systems .
2016-03-08 01:00:26 -05:00
* @ since 4.5 . 0 Allows for Windows network shares .
2018-07-05 11:21:25 -04:00
* @ since 4.9 . 7 Allows for PHP file wrappers .
2014-02-10 18:00:15 -05:00
*
* @ param string $path Path to normalize .
* @ return string Normalized path .
*/
function wp_normalize_path ( $path ) {
2017-12-11 23:16:47 -05:00
$wrapper = '' ;
2020-01-28 19:45:18 -05:00
2017-12-11 23:16:47 -05:00
if ( wp_is_stream ( $path ) ) {
list ( $wrapper , $path ) = explode ( '://' , $path , 2 );
2020-01-28 19:45:18 -05:00
$wrapper .= '://' ;
2017-12-11 23:16:47 -05:00
}
2022-01-25 08:55:05 -05:00
// Standardize all paths to use '/'.
2014-02-10 18:00:15 -05:00
$path = str_replace ( '\\' , '/' , $path );
2017-12-11 23:16:47 -05:00
// Replace multiple slashes down to a singular, allowing for network shares having two slashes.
2016-03-08 01:00:26 -05:00
$path = preg_replace ( '|(?<=.)/+|' , '/' , $path );
2017-12-11 23:16:47 -05:00
2020-01-28 19:45:18 -05:00
// Windows paths should uppercase the drive letter.
2015-09-13 21:59:25 -04:00
if ( ':' === substr ( $path , 1 , 1 ) ) {
$path = ucfirst ( $path );
}
2017-12-11 23:16:47 -05:00
return $wrapper . $path ;
2014-02-10 18:00:15 -05:00
}
2011-03-24 22:42:20 -04:00
/**
2022-08-12 05:53:11 -04:00
* Determines a writable directory for temporary files .
2014-06-30 21:44:15 -04:00
*
* Function ' s preference is the return value of sys_get_temp_dir (),
2012-09-26 01:02:58 -04:00
* followed by your PHP temporary upload directory , followed by WP_CONTENT_DIR ,
* before finally defaulting to / tmp /
2011-03-24 22:42:20 -04:00
*
2012-09-26 01:02:58 -04:00
* In the event that this function does not find a writable location ,
2014-06-30 21:44:15 -04:00
* It may be overridden by the WP_TEMP_DIR constant in your wp - config . php file .
2011-03-24 22:42:20 -04:00
*
* @ since 2.5 . 0
*
2014-06-30 21:44:15 -04:00
* @ return string Writable temporary directory .
2011-03-24 22:42:20 -04:00
*/
function get_temp_dir () {
2015-05-29 11:43:29 -04:00
static $temp = '' ;
2017-11-30 18:11:00 -05:00
if ( defined ( 'WP_TEMP_DIR' ) ) {
return trailingslashit ( WP_TEMP_DIR );
}
2011-03-24 22:42:20 -04:00
2017-11-30 18:11:00 -05:00
if ( $temp ) {
2014-03-01 16:45:15 -05:00
return trailingslashit ( $temp );
2017-11-30 18:11:00 -05:00
}
2011-03-24 22:42:20 -04:00
2017-11-30 18:11:00 -05:00
if ( function_exists ( 'sys_get_temp_dir' ) ) {
2011-03-24 22:42:20 -04:00
$temp = sys_get_temp_dir ();
2017-11-30 18:11:00 -05:00
if ( @ is_dir ( $temp ) && wp_is_writable ( $temp ) ) {
2014-03-01 16:45:15 -05:00
return trailingslashit ( $temp );
2017-11-30 18:11:00 -05:00
}
2011-03-24 22:42:20 -04:00
}
2017-11-30 18:11:00 -05:00
$temp = ini_get ( 'upload_tmp_dir' );
if ( @ is_dir ( $temp ) && wp_is_writable ( $temp ) ) {
2014-03-01 16:45:15 -05:00
return trailingslashit ( $temp );
2017-11-30 18:11:00 -05:00
}
2011-03-24 22:42:20 -04:00
2012-09-26 01:02:58 -04:00
$temp = WP_CONTENT_DIR . '/' ;
2017-11-30 18:11:00 -05:00
if ( is_dir ( $temp ) && wp_is_writable ( $temp ) ) {
2012-09-26 01:02:58 -04:00
return $temp ;
2017-11-30 18:11:00 -05:00
}
2012-09-26 01:02:58 -04:00
2015-05-25 12:11:25 -04:00
return '/tmp/' ;
2011-03-24 22:42:20 -04:00
}
2013-01-03 03:04:11 -05:00
/**
2022-08-12 05:53:11 -04:00
* Determines if a directory is writable .
2013-01-03 03:04:11 -05:00
*
2014-06-30 21:44:15 -04:00
* This function is used to work around certain ACL issues in PHP primarily
* affecting Windows Servers .
2013-01-03 03:04:11 -05:00
*
* @ since 3.6 . 0
*
2014-06-30 21:44:15 -04:00
* @ see win_is_writable ()
*
* @ param string $path Path to check for write - ability .
* @ return bool Whether the path is writable .
2013-01-03 03:04:11 -05:00
*/
function wp_is_writable ( $path ) {
2017-11-30 18:11:00 -05:00
if ( 'WIN' === strtoupper ( substr ( PHP_OS , 0 , 3 ) ) ) {
2013-01-03 03:04:11 -05:00
return win_is_writable ( $path );
2017-11-30 18:11:00 -05:00
} else {
2013-01-03 03:04:11 -05:00
return @ is_writable ( $path );
2017-11-30 18:11:00 -05:00
}
2013-01-03 03:04:11 -05:00
}
2012-09-26 01:08:26 -04:00
/**
* Workaround for Windows bug in is_writable () function
*
2013-02-15 11:12:40 -05:00
* PHP has issues with Windows ACL ' s for determine if a
2013-01-03 02:56:38 -05:00
* directory is writable or not , this works around them by
* checking the ability to open files rather than relying
* upon PHP to interprate the OS ACL .
*
2012-09-26 01:08:26 -04:00
* @ since 2.8 . 0
*
2016-06-10 00:50:33 -04:00
* @ see https :// bugs . php . net / bug . php ? id = 27609
* @ see https :// bugs . php . net / bug . php ? id = 30931
2014-06-30 21:44:15 -04:00
*
* @ param string $path Windows path to check for write - ability .
* @ return bool Whether the path is writable .
2012-09-26 01:08:26 -04:00
*/
function win_is_writable ( $path ) {
2020-02-09 11:55:09 -05:00
if ( '/' === $path [ strlen ( $path ) - 1 ] ) {
2020-01-28 19:45:18 -05:00
// If it looks like a directory, check a random file within the directory.
2017-11-30 18:11:00 -05:00
return win_is_writable ( $path . uniqid ( mt_rand () ) . '.tmp' );
2020-01-28 19:45:18 -05:00
} elseif ( is_dir ( $path ) ) {
// If it's a directory (and not a file), check a random file within the directory.
2012-09-26 01:08:26 -04:00
return win_is_writable ( $path . '/' . uniqid ( mt_rand () ) . '.tmp' );
2015-01-08 02:05:25 -05:00
}
2020-01-28 19:45:18 -05:00
// Check tmp file for read/write capabilities.
2017-11-30 18:11:00 -05:00
$should_delete_tmp_file = ! file_exists ( $path );
2020-01-28 19:45:18 -05:00
$f = @ fopen ( $path , 'a' );
2020-02-09 11:55:09 -05:00
if ( false === $f ) {
2012-09-26 01:08:26 -04:00
return false ;
2017-11-30 18:11:00 -05:00
}
2012-09-26 01:08:26 -04:00
fclose ( $f );
2020-01-28 19:45:18 -05:00
2017-11-30 18:11:00 -05:00
if ( $should_delete_tmp_file ) {
2012-09-26 01:08:26 -04:00
unlink ( $path );
2017-11-30 18:11:00 -05:00
}
2020-01-28 19:45:18 -05:00
2012-09-26 01:08:26 -04:00
return true ;
}
2016-02-17 17:51:26 -05:00
/**
2016-03-10 00:37:27 -05:00
* Retrieves uploads directory information .
2016-02-17 17:51:26 -05:00
*
* Same as wp_upload_dir () but " light weight " as it doesn ' t attempt to create the uploads directory .
2016-03-10 00:37:27 -05:00
* Intended for use in themes , when only 'basedir' and 'baseurl' are needed , generally in all cases
* when not uploading files .
2016-02-17 17:51:26 -05:00
*
* @ since 4.5 . 0
*
2016-03-10 00:37:27 -05:00
* @ see wp_upload_dir ()
*
2016-02-17 17:51:26 -05:00
* @ return array See wp_upload_dir () for description .
*/
function wp_get_upload_dir () {
return wp_upload_dir ( null , false );
}
2008-08-09 00:51:51 -04:00
/**
2019-09-17 17:03:54 -04:00
* Returns an array containing the current upload directory ' s path and URL .
2008-08-09 00:51:51 -04:00
*
2008-08-10 12:45:50 -04:00
* Checks the 'upload_path' option , which should be from the web root folder ,
* and if it isn ' t empty it will be used . If it is empty , then the path will be
* 'WP_CONTENT_DIR/uploads' . If the 'UPLOADS' constant is defined , then it will
* override the 'upload_path' option and 'WP_CONTENT_DIR/uploads' path .
*
* The upload URL path is set either by the 'upload_url_path' option or by using
* the 'WP_CONTENT_URL' constant and appending '/uploads' to the path .
*
* If the 'uploads_use_yearmonth_folders' is set to true ( checkbox if checked in
* the administration settings panel ), then the time will be used . The format
* will be year first and then month .
*
* If the path couldn ' t be created , then an error will be returned with the key
* 'error' containing the error message . The error suggests that the parent
* directory is not writable by the server .
*
2008-08-09 00:51:51 -04:00
* @ since 2.0 . 0
2016-02-17 17:51:26 -05:00
* @ uses _wp_upload_dir ()
2008-08-09 00:51:51 -04:00
*
2014-06-30 21:44:15 -04:00
* @ param string $time Optional . Time formatted in 'yyyy/mm' . Default null .
2016-05-13 14:41:31 -04:00
* @ param bool $create_dir Optional . Whether to check and create the uploads directory .
* Default true for backward compatibility .
2016-02-17 17:51:26 -05:00
* @ param bool $refresh_cache Optional . Whether to refresh the cache . Default false .
2019-09-17 17:03:54 -04:00
* @ return array {
* Array of information about the upload directory .
*
* @ type string $path Base directory and subdirectory or full path to upload directory .
* @ type string $url Base URL and subdirectory or absolute URL to upload directory .
* @ type string $subdir Subdirectory if uploads use year / month folders option is on .
* @ type string $basedir Path without subdir .
* @ type string $baseurl URL path without subdir .
* @ type string | false $error False or error message .
* }
2008-08-09 00:51:51 -04:00
*/
2016-02-17 17:51:26 -05:00
function wp_upload_dir ( $time = null , $create_dir = true , $refresh_cache = false ) {
2016-04-21 15:58:27 -04:00
static $cache = array (), $tested_paths = array ();
2016-02-17 17:51:26 -05:00
$key = sprintf ( '%d-%s' , get_current_blog_id (), ( string ) $time );
if ( $refresh_cache || empty ( $cache [ $key ] ) ) {
$cache [ $key ] = _wp_upload_dir ( $time );
}
/**
2016-05-22 14:36:27 -04:00
* Filters the uploads directory data .
2016-02-17 17:51:26 -05:00
*
* @ since 2.0 . 0
*
2019-09-17 17:03:54 -04:00
* @ param array $uploads {
* Array of information about the upload directory .
*
* @ type string $path Base directory and subdirectory or full path to upload directory .
* @ type string $url Base URL and subdirectory or absolute URL to upload directory .
* @ type string $subdir Subdirectory if uploads use year / month folders option is on .
* @ type string $basedir Path without subdir .
* @ type string $baseurl URL path without subdir .
* @ type string | false $error False or error message .
* }
2016-02-17 17:51:26 -05:00
*/
$uploads = apply_filters ( 'upload_dir' , $cache [ $key ] );
if ( $create_dir ) {
$path = $uploads [ 'path' ];
2016-04-21 15:58:27 -04:00
if ( array_key_exists ( $path , $tested_paths ) ) {
$uploads [ 'error' ] = $tested_paths [ $path ];
} else {
2016-02-17 17:51:26 -05:00
if ( ! wp_mkdir_p ( $path ) ) {
Code Modernization: Replace usage of `strpos()` with `str_starts_with()`.
`str_starts_with()` was introduced in PHP 8.0 to perform a case-sensitive check indicating if the string to search in (haystack) begins with the given substring (needle).
WordPress core includes a polyfill for `str_starts_with()` on PHP < 8.0 as of WordPress 5.9.
This commit replaces `0 === strpos( ... )` with `str_starts_with()` in core files, making the code more readable and consistent, as well as improving performance.
While `strpos()` is slightly faster than the polyfill on PHP < 8.0, `str_starts_with()` is noticeably faster on PHP 8.0+, as it is optimized to avoid unnecessarily searching along the whole haystack if it does not find the needle.
Follow-up to [52039], [52040], [52326].
Props spacedmonkey, costdev, sabernhardt, mukesh27, desrosj, jorbin, TobiasBg, ayeshrajans, lgadzhev, SergeyBiryukov.
Fixes #58012.
Built from https://develop.svn.wordpress.org/trunk@55703
git-svn-id: http://core.svn.wordpress.org/trunk@55215 1a063a9b-81f0-0310-95a4-ce76da25c4cd
2023-05-02 11:45:22 -04:00
if ( str_starts_with ( $uploads [ 'basedir' ], ABSPATH ) ) {
2016-02-17 17:51:26 -05:00
$error_path = str_replace ( ABSPATH , '' , $uploads [ 'basedir' ] ) . $uploads [ 'subdir' ];
} else {
2019-03-01 15:58:52 -05:00
$error_path = wp_basename ( $uploads [ 'basedir' ] ) . $uploads [ 'subdir' ];
2016-02-17 17:51:26 -05:00
}
2016-08-23 19:48:28 -04:00
$uploads [ 'error' ] = sprintf (
2019-09-02 20:41:05 -04:00
/* translators: %s: Directory path. */
2016-08-23 19:48:28 -04:00
__ ( 'Unable to create directory %s. Is its parent directory writable by the server?' ),
esc_html ( $error_path )
);
2016-02-17 17:51:26 -05:00
}
2016-04-21 15:58:27 -04:00
$tested_paths [ $path ] = $uploads [ 'error' ];
2016-02-17 17:51:26 -05:00
}
}
return $uploads ;
}
/**
* A non - filtered , non - cached version of wp_upload_dir () that doesn ' t check the path .
*
2016-12-27 04:21:44 -05:00
* @ since 4.5 . 0
2016-02-17 17:51:26 -05:00
* @ access private
*
* @ param string $time Optional . Time formatted in 'yyyy/mm' . Default null .
* @ return array See wp_upload_dir ()
*/
function _wp_upload_dir ( $time = null ) {
2017-11-30 18:11:00 -05:00
$siteurl = get_option ( 'siteurl' );
2012-09-11 18:22:20 -04:00
$upload_path = trim ( get_option ( 'upload_path' ) );
2020-05-16 14:42:12 -04:00
if ( empty ( $upload_path ) || 'wp-content/uploads' === $upload_path ) {
2008-07-16 12:49:22 -04:00
$dir = WP_CONTENT_DIR . '/uploads' ;
Code Modernization: Replace usage of `strpos()` with `str_starts_with()`.
`str_starts_with()` was introduced in PHP 8.0 to perform a case-sensitive check indicating if the string to search in (haystack) begins with the given substring (needle).
WordPress core includes a polyfill for `str_starts_with()` on PHP < 8.0 as of WordPress 5.9.
This commit replaces `0 === strpos( ... )` with `str_starts_with()` in core files, making the code more readable and consistent, as well as improving performance.
While `strpos()` is slightly faster than the polyfill on PHP < 8.0, `str_starts_with()` is noticeably faster on PHP 8.0+, as it is optimized to avoid unnecessarily searching along the whole haystack if it does not find the needle.
Follow-up to [52039], [52040], [52326].
Props spacedmonkey, costdev, sabernhardt, mukesh27, desrosj, jorbin, TobiasBg, ayeshrajans, lgadzhev, SergeyBiryukov.
Fixes #58012.
Built from https://develop.svn.wordpress.org/trunk@55703
git-svn-id: http://core.svn.wordpress.org/trunk@55215 1a063a9b-81f0-0310-95a4-ce76da25c4cd
2023-05-02 11:45:22 -04:00
} elseif ( ! str_starts_with ( $upload_path , ABSPATH ) ) {
2020-01-28 19:45:18 -05:00
// $dir is absolute, $upload_path is (maybe) relative to ABSPATH.
2012-09-11 18:22:20 -04:00
$dir = path_join ( ABSPATH , $upload_path );
2009-12-15 12:53:51 -05:00
} else {
2008-07-16 12:49:22 -04:00
$dir = $upload_path ;
2009-12-15 12:53:51 -05:00
}
2008-08-09 01:36:14 -04:00
2019-07-02 19:42:58 -04:00
$url = get_option ( 'upload_url_path' );
if ( ! $url ) {
2020-05-16 14:42:12 -04:00
if ( empty ( $upload_path ) || ( 'wp-content/uploads' === $upload_path ) || ( $upload_path == $dir ) ) {
2008-07-16 12:49:22 -04:00
$url = WP_CONTENT_URL . '/uploads' ;
2017-11-30 18:11:00 -05:00
} else {
2008-07-16 12:49:22 -04:00
$url = trailingslashit ( $siteurl ) . $upload_path ;
2017-11-30 18:11:00 -05:00
}
2008-07-16 12:49:22 -04:00
}
2006-06-07 19:17:59 -04:00
2014-06-30 21:44:15 -04:00
/*
* Honor the value of UPLOADS . This happens as long as ms - files rewriting is disabled .
* We also sometimes obey UPLOADS when rewriting is enabled -- see the next block .
*/
2015-10-07 13:11:25 -04:00
if ( defined ( 'UPLOADS' ) && ! ( is_multisite () && get_site_option ( 'ms_files_rewriting' ) ) ) {
2006-06-07 19:17:59 -04:00
$dir = ABSPATH . UPLOADS ;
2007-10-11 01:46:57 -04:00
$url = trailingslashit ( $siteurl ) . UPLOADS ;
2006-06-07 19:17:59 -04:00
}
2008-07-07 19:53:54 -04:00
2020-01-28 19:45:18 -05:00
// If multisite (and if not the main site in a post-MU network).
2013-08-27 23:36:09 -04:00
if ( is_multisite () && ! ( is_main_network () && is_main_site () && defined ( 'MULTISITE' ) ) ) {
2012-09-27 00:56:58 -04:00
2015-10-07 13:11:25 -04:00
if ( ! get_site_option ( 'ms_files_rewriting' ) ) {
2014-06-30 21:44:15 -04:00
/*
* If ms - files rewriting is disabled ( networks created post - 3.5 ), it is fairly
* straightforward : Append sites /% d if we ' re not on the main site ( for post - MU
* networks ) . ( The extra directory prevents a four - digit ID from conflicting with
* a year - based directory for the main site . But if a MU - era network has disabled
* ms - files rewriting manually , they don ' t need the extra directory , as they never
* had wp - content / uploads for the main site . )
*/
2012-09-27 00:56:58 -04:00
2017-11-30 18:11:00 -05:00
if ( defined ( 'MULTISITE' ) ) {
2012-10-12 18:05:02 -04:00
$ms_dir = '/sites/' . get_current_blog_id ();
2017-11-30 18:11:00 -05:00
} else {
2012-10-12 18:05:02 -04:00
$ms_dir = '/' . get_current_blog_id ();
2017-11-30 18:11:00 -05:00
}
2012-10-12 18:05:02 -04:00
$dir .= $ms_dir ;
$url .= $ms_dir ;
} elseif ( defined ( 'UPLOADS' ) && ! ms_is_switched () ) {
2014-06-30 21:44:15 -04:00
/*
* Handle the old - form ms - files . php rewriting if the network still has that enabled .
* When ms - files rewriting is enabled , then we only listen to UPLOADS when :
* 1 ) We are not on the main site in a post - MU network , as wp - content / uploads is used
* there , and
* 2 ) We are not switched , as ms_upload_constants () hardcodes these constants to reflect
* the original blog ID .
*
* Rather than UPLOADS , we actually use BLOGUPLOADDIR if it is set , as it is absolute .
* ( And it will be set , see ms_upload_constants () . ) Otherwise , UPLOADS can be used , as
* as it is relative to ABSPATH . For the final piece : when UPLOADS is used with ms - files
* rewriting in multisite , the resulting URL is / files . ( #WP22702 for background.)
*/
2012-10-12 18:05:02 -04:00
2017-11-30 18:11:00 -05:00
if ( defined ( 'BLOGUPLOADDIR' ) ) {
2012-09-11 18:22:20 -04:00
$dir = untrailingslashit ( BLOGUPLOADDIR );
2017-11-30 18:11:00 -05:00
} else {
2012-12-03 17:24:06 -05:00
$dir = ABSPATH . UPLOADS ;
2017-11-30 18:11:00 -05:00
}
2012-12-03 17:24:06 -05:00
$url = trailingslashit ( $siteurl ) . 'files' ;
2012-09-11 18:22:20 -04:00
}
2010-01-26 15:02:11 -05:00
}
2010-01-26 14:04:55 -05:00
2012-09-11 18:06:49 -04:00
$basedir = $dir ;
$baseurl = $url ;
2008-07-07 19:53:54 -04:00
2008-02-22 12:46:03 -05:00
$subdir = '' ;
2007-10-11 01:46:57 -04:00
if ( get_option ( 'uploads_use_yearmonth_folders' ) ) {
2020-01-28 19:45:18 -05:00
// Generate the yearly and monthly directories.
2017-11-30 18:11:00 -05:00
if ( ! $time ) {
2007-12-16 16:34:48 -05:00
$time = current_time ( 'mysql' );
2017-11-30 18:11:00 -05:00
}
$y = substr ( $time , 0 , 4 );
$m = substr ( $time , 5 , 2 );
2008-02-22 12:46:03 -05:00
$subdir = " / $y / $m " ;
2006-06-07 19:17:59 -04:00
}
2008-03-02 15:17:30 -05:00
2008-02-22 12:46:03 -05:00
$dir .= $subdir ;
$url .= $subdir ;
2006-06-07 19:17:59 -04:00
2016-02-17 17:51:26 -05:00
return array (
'path' => $dir ,
'url' => $url ,
'subdir' => $subdir ,
'basedir' => $basedir ,
'baseurl' => $baseurl ,
'error' => false ,
);
2006-06-07 19:17:59 -04:00
}
2008-08-09 00:51:51 -04:00
/**
2022-08-12 05:53:11 -04:00
* Gets a filename that is sanitized and unique for the given directory .
2008-08-09 00:51:51 -04:00
*
2008-08-10 12:45:50 -04:00
* If the filename is not unique , then a number will be added to the filename
2020-07-25 08:31:05 -04:00
* before the extension , and will continue adding numbers until the filename
* is unique .
2008-08-10 12:45:50 -04:00
*
2020-07-25 08:31:05 -04:00
* The callback function allows the caller to use their own method to create
* unique file names . If defined , the callback should take three arguments :
* - directory , base filename , and extension - and return a unique filename .
2008-08-09 00:51:51 -04:00
*
2010-12-01 14:24:38 -05:00
* @ since 2.5 . 0
2008-08-09 00:51:51 -04:00
*
2014-06-30 21:44:15 -04:00
* @ param string $dir Directory .
* @ param string $filename File name .
2015-09-25 19:58:25 -04:00
* @ param callable $unique_filename_callback Callback . Default null .
2008-08-10 12:45:50 -04:00
* @ return string New filename , if given wasn ' t unique .
2008-08-09 00:51:51 -04:00
*/
function wp_unique_filename ( $dir , $filename , $unique_filename_callback = null ) {
2014-06-30 21:44:15 -04:00
// Sanitize the file name before we begin processing.
2017-11-30 18:11:00 -05:00
$filename = sanitize_file_name ( $filename );
2019-12-16 18:44:04 -05:00
$ext2 = null ;
2009-05-04 16:20:48 -04:00
2021-08-24 16:52:03 -04:00
// Initialize vars used in the wp_unique_filename filter.
$number = '' ;
$alt_filenames = array ();
2014-06-30 21:44:15 -04:00
// Separate the filename into a name and extension.
2017-11-30 18:11:00 -05:00
$ext = pathinfo ( $filename , PATHINFO_EXTENSION );
2016-08-20 19:36:28 -04:00
$name = pathinfo ( $filename , PATHINFO_BASENAME );
2019-12-06 17:28:00 -05:00
2016-08-20 19:36:28 -04:00
if ( $ext ) {
$ext = '.' . $ext ;
}
2009-05-24 19:47:49 -04:00
2014-06-30 21:44:15 -04:00
// Edge case: if file is named '.ext', treat as an empty name.
2016-08-20 19:36:28 -04:00
if ( $name === $ext ) {
2008-03-21 00:03:33 -04:00
$name = '' ;
2016-08-20 19:36:28 -04:00
}
2008-02-05 01:47:27 -05:00
2014-06-30 21:44:15 -04:00
/*
* Increment the file number until we have a unique file to save in $dir .
* Use callback if supplied .
*/
2010-04-02 19:54:56 -04:00
if ( $unique_filename_callback && is_callable ( $unique_filename_callback ) ) {
2010-10-27 18:27:06 -04:00
$filename = call_user_func ( $unique_filename_callback , $dir , $name , $ext );
2007-12-16 16:34:48 -05:00
} else {
2021-08-24 16:52:03 -04:00
$fname = pathinfo ( $filename , PATHINFO_FILENAME );
2019-12-06 17:28:00 -05:00
// Always append a number to file names that can potentially match image sub-size file names.
if ( $fname && preg_match ( '/-(?:\d+x\d+|scaled|rotated)$/' , $fname ) ) {
$number = 1 ;
// At this point the file name may not be unique. This is tested below and the $number is incremented.
$filename = str_replace ( " { $fname } { $ext } " , " { $fname } - { $number } { $ext } " , $filename );
}
2008-03-21 00:03:33 -04:00
2021-12-10 15:30:05 -05:00
/*
* Get the mime type . Uploaded files were already checked with wp_check_filetype_and_ext ()
* in _wp_handle_upload () . Using wp_check_filetype () would be sufficient here .
*/
2021-08-24 16:52:03 -04:00
$file_type = wp_check_filetype ( $filename );
$mime_type = $file_type [ 'type' ];
2016-01-15 04:39:26 -05:00
Code Modernization: Replace usage of `strpos()` with `str_starts_with()`.
`str_starts_with()` was introduced in PHP 8.0 to perform a case-sensitive check indicating if the string to search in (haystack) begins with the given substring (needle).
WordPress core includes a polyfill for `str_starts_with()` on PHP < 8.0 as of WordPress 5.9.
This commit replaces `0 === strpos( ... )` with `str_starts_with()` in core files, making the code more readable and consistent, as well as improving performance.
While `strpos()` is slightly faster than the polyfill on PHP < 8.0, `str_starts_with()` is noticeably faster on PHP 8.0+, as it is optimized to avoid unnecessarily searching along the whole haystack if it does not find the needle.
Follow-up to [52039], [52040], [52326].
Props spacedmonkey, costdev, sabernhardt, mukesh27, desrosj, jorbin, TobiasBg, ayeshrajans, lgadzhev, SergeyBiryukov.
Fixes #58012.
Built from https://develop.svn.wordpress.org/trunk@55703
git-svn-id: http://core.svn.wordpress.org/trunk@55215 1a063a9b-81f0-0310-95a4-ce76da25c4cd
2023-05-02 11:45:22 -04:00
$is_image = ( ! empty ( $mime_type ) && str_starts_with ( $mime_type , 'image/' ) );
2021-08-24 16:52:03 -04:00
$upload_dir = wp_get_upload_dir ();
$lc_filename = null ;
2019-12-06 17:28:00 -05:00
2021-08-24 16:52:03 -04:00
$lc_ext = strtolower ( $ext );
$_dir = trailingslashit ( $dir );
2019-12-06 17:28:00 -05:00
2021-12-10 15:30:05 -05:00
/*
* If the extension is uppercase add an alternate file name with lowercase extension .
* Both need to be tested for uniqueness as the extension will be changed to lowercase
* for better compatibility with different filesystems . Fixes an inconsistency in WP < 2.9
* where uppercase extensions were allowed but image sub - sizes were created with
* lowercase extensions .
*/
2021-08-24 16:52:03 -04:00
if ( $ext && $lc_ext !== $ext ) {
$lc_filename = preg_replace ( '|' . preg_quote ( $ext ) . '$|' , $lc_ext , $filename );
}
2021-12-10 15:30:05 -05:00
/*
* Increment the number added to the file name if there are any files in $dir
* whose names match one of the possible name variations .
*/
2021-08-24 16:52:03 -04:00
while ( file_exists ( $_dir . $filename ) || ( $lc_filename && file_exists ( $_dir . $lc_filename ) ) ) {
$new_number = ( int ) $number + 1 ;
if ( $lc_filename ) {
2021-12-10 15:30:05 -05:00
$lc_filename = str_replace (
array ( " - { $number } { $lc_ext } " , " { $number } { $lc_ext } " ),
" - { $new_number } { $lc_ext } " ,
$lc_filename
);
2019-12-06 17:28:00 -05:00
}
2021-08-24 16:52:03 -04:00
if ( '' === " { $number } { $ext } " ) {
$filename = " { $filename } - { $new_number } " ;
} else {
2021-12-10 15:30:05 -05:00
$filename = str_replace (
array ( " - { $number } { $ext } " , " { $number } { $ext } " ),
" - { $new_number } { $ext } " ,
$filename
);
2021-08-24 16:52:03 -04:00
}
$number = $new_number ;
}
// Change the extension to lowercase if needed.
if ( $lc_filename ) {
$filename = $lc_filename ;
2009-11-25 00:04:30 -05:00
}
2008-03-21 00:03:33 -04:00
2021-12-10 15:30:05 -05:00
/*
* Prevent collisions with existing file names that contain dimension - like strings
* ( whether they are subsizes or originals uploaded prior to #42437).
*/
2021-08-24 16:52:03 -04:00
$files = array ();
$count = 10000 ;
2019-12-06 17:28:00 -05:00
// The (resized) image files would have name and extension, and will be in the uploads dir.
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 10:36:26 -04:00
if ( $name && $ext && @ is_dir ( $dir ) && str_contains ( $dir , $upload_dir [ 'basedir' ] ) ) {
2020-07-07 06:20:03 -04:00
/**
* Filters the file list used for calculating a unique filename for a newly added file .
*
* Returning an array from the filter will effectively short - circuit retrieval
* from the filesystem and return the passed value instead .
*
* @ since 5.5 . 0
*
* @ param array | null $files The list of files to use for filename comparisons .
* Default null ( to retrieve the list from the filesystem ) .
* @ param string $dir The directory for the new file .
* @ param string $filename The proposed filename for the new file .
*/
$files = apply_filters ( 'pre_wp_unique_filename_file_list' , null , $dir , $filename );
if ( null === $files ) {
// List of all files and directories contained in $dir.
$files = @ scandir ( $dir );
}
2019-12-16 18:23:06 -05:00
if ( ! empty ( $files ) ) {
// Remove "dot" dirs.
$files = array_diff ( $files , array ( '.' , '..' ) );
}
2019-12-06 17:28:00 -05:00
if ( ! empty ( $files ) ) {
2021-08-24 16:52:03 -04:00
$count = count ( $files );
2019-12-16 18:44:04 -05:00
2021-12-10 15:30:05 -05:00
/*
* Ensure this never goes into infinite loop as it uses pathinfo () and regex in the check ,
* but string replacement for the changes .
*/
2021-08-24 16:52:03 -04:00
$i = 0 ;
2019-12-16 18:44:04 -05:00
while ( $i <= $count && _wp_check_existing_file_names ( $filename , $files ) ) {
2019-12-06 17:28:00 -05:00
$new_number = ( int ) $number + 1 ;
2021-08-24 16:52:03 -04:00
// If $ext is uppercase it was replaced with the lowercase version after the previous loop.
2021-12-10 15:30:05 -05:00
$filename = str_replace (
array ( " - { $number } { $lc_ext } " , " { $number } { $lc_ext } " ),
" - { $new_number } { $lc_ext } " ,
$filename
);
2021-08-24 16:52:03 -04:00
$number = $new_number ;
$i ++ ;
}
}
}
2021-12-10 15:30:05 -05:00
/*
* Check if an image will be converted after uploading or some existing image sub - size file names may conflict
* when regenerated . If yes , ensure the new file name will be unique and will produce unique sub - sizes .
*/
2021-08-24 16:52:03 -04:00
if ( $is_image ) {
2021-11-08 05:44:59 -05:00
/** This filter is documented in wp-includes/class-wp-image-editor.php */
2022-09-19 18:53:10 -04:00
$output_formats = apply_filters ( 'image_editor_output_format' , array (), $_dir . $filename , $mime_type );
2021-08-24 16:52:03 -04:00
$alt_types = array ();
if ( ! empty ( $output_formats [ $mime_type ] ) ) {
// The image will be converted to this format/mime type.
$alt_mime_type = $output_formats [ $mime_type ];
// Other types of images whose names may conflict if their sub-sizes are regenerated.
2021-08-30 10:09:58 -04:00
$alt_types = array_keys ( array_intersect ( $output_formats , array ( $mime_type , $alt_mime_type ) ) );
2021-08-24 16:52:03 -04:00
$alt_types [] = $alt_mime_type ;
} elseif ( ! empty ( $output_formats ) ) {
$alt_types = array_keys ( array_intersect ( $output_formats , array ( $mime_type ) ) );
}
// Remove duplicates and the original mime type. It will be added later if needed.
$alt_types = array_unique ( array_diff ( $alt_types , array ( $mime_type ) ) );
foreach ( $alt_types as $alt_type ) {
$alt_ext = wp_get_default_extension_for_mime_type ( $alt_type );
if ( ! $alt_ext ) {
continue ;
}
$alt_ext = " . { $alt_ext } " ;
$alt_filename = preg_replace ( '|' . preg_quote ( $lc_ext ) . '$|' , $alt_ext , $filename );
$alt_filenames [ $alt_ext ] = $alt_filename ;
}
if ( ! empty ( $alt_filenames ) ) {
2021-12-10 15:30:05 -05:00
/*
* Add the original filename . It needs to be checked again
* together with the alternate filenames when $number is incremented .
*/
2021-08-24 16:52:03 -04:00
$alt_filenames [ $lc_ext ] = $filename ;
// Ensure no infinite loop.
$i = 0 ;
while ( $i <= $count && _wp_check_alternate_file_names ( $alt_filenames , $_dir , $files ) ) {
$new_number = ( int ) $number + 1 ;
foreach ( $alt_filenames as $alt_ext => $alt_filename ) {
2021-12-10 15:30:05 -05:00
$alt_filenames [ $alt_ext ] = str_replace (
array ( " - { $number } { $alt_ext } " , " { $number } { $alt_ext } " ),
" - { $new_number } { $alt_ext } " ,
$alt_filename
);
2021-08-24 16:52:03 -04:00
}
2021-12-10 15:30:05 -05:00
/*
* Also update the $number in ( the output ) $filename .
* If the extension was uppercase it was already replaced with the lowercase version .
*/
$filename = str_replace (
array ( " - { $number } { $lc_ext } " , " { $number } { $lc_ext } " ),
" - { $new_number } { $lc_ext } " ,
$filename
);
2021-08-24 16:52:03 -04:00
$number = $new_number ;
2019-12-16 18:44:04 -05:00
$i ++ ;
2019-12-06 17:28:00 -05:00
}
2015-10-20 00:05:25 -04:00
}
2007-12-16 16:34:48 -05:00
}
}
2008-02-05 01:47:27 -05:00
2019-12-06 17:28:00 -05:00
/**
* Filters the result when generating a unique file name .
*
* @ since 4.5 . 0
2021-08-24 16:52:03 -04:00
* @ since 5.8 . 1 The `$alt_filenames` and `$number` parameters were added .
2019-12-06 17:28:00 -05:00
*
* @ param string $filename Unique file name .
2021-11-19 09:44:01 -05:00
* @ param string $ext File extension . Example : " .png " .
2019-12-06 17:28:00 -05:00
* @ param string $dir Directory path .
* @ param callable | null $unique_filename_callback Callback function that generates the unique file name .
2021-08-24 16:52:03 -04:00
* @ param string [] $alt_filenames Array of alternate file names that were checked for collisions .
* @ param int | string $number The highest number that was used to make the file name unique
* or an empty string if unused .
2019-12-06 17:28:00 -05:00
*/
2021-08-24 16:52:03 -04:00
return apply_filters ( 'wp_unique_filename' , $filename , $ext , $dir , $unique_filename_callback , $alt_filenames , $number );
}
/**
* Helper function to test if each of an array of file names could conflict with existing files .
*
* @ since 5.8 . 1
* @ access private
*
* @ param string [] $filenames Array of file names to check .
* @ param string $dir The directory containing the files .
* @ param array $files An array of existing files in the directory . May be empty .
* @ return bool True if the tested file name could match an existing file , false otherwise .
*/
function _wp_check_alternate_file_names ( $filenames , $dir , $files ) {
foreach ( $filenames as $filename ) {
if ( file_exists ( $dir . $filename ) ) {
return true ;
}
if ( ! empty ( $files ) && _wp_check_existing_file_names ( $filename , $files ) ) {
return true ;
}
}
return false ;
2007-12-16 16:34:48 -05:00
}
2019-12-06 17:28:00 -05:00
/**
* Helper function to check if a file name could match an existing image sub - size file name .
*
* @ since 5.3 . 1
* @ access private
*
* @ param string $filename The file name to check .
2020-07-22 20:48:06 -04:00
* @ param array $files An array of existing files in the directory .
* @ return bool True if the tested file name could match an existing file , false otherwise .
2019-12-06 17:28:00 -05:00
*/
function _wp_check_existing_file_names ( $filename , $files ) {
$fname = pathinfo ( $filename , PATHINFO_FILENAME );
$ext = pathinfo ( $filename , PATHINFO_EXTENSION );
2020-01-28 19:45:18 -05:00
// Edge case, file names like `.ext`.
2019-12-06 17:28:00 -05:00
if ( empty ( $fname ) ) {
return false ;
}
if ( $ext ) {
$ext = " . $ext " ;
}
2019-12-16 18:44:04 -05:00
$regex = '/^' . preg_quote ( $fname ) . '-(?:\d+x\d+|scaled|rotated)' . preg_quote ( $ext ) . '$/i' ;
2019-12-06 17:28:00 -05:00
foreach ( $files as $file ) {
if ( preg_match ( $regex , $file ) ) {
return true ;
}
}
return false ;
}
2008-08-10 12:45:50 -04:00
/**
2022-08-12 05:53:11 -04:00
* Creates a file in the upload folder with given content .
2008-08-10 12:45:50 -04:00
*
* If there is an error , then the key 'error' will exist with the error message .
* If success , then the key 'file' will have the unique file path , the 'url' key
* will have the link to the new file . and the 'error' key will be set to false .
*
* This function will not move an uploaded file to the upload folder . It will
* create a new file with the content in $bits parameter . If you move the upload
* file , read the content of the uploaded file , and then you can give the
* filename and content to this function , which will add it to the upload
* folder .
*
* The permissions will be set on the new file automatically by this function .
*
* @ since 2.0 . 0
*
2020-07-23 17:11:05 -04:00
* @ param string $name Filename .
* @ param null | string $deprecated Never used . Set to null .
* @ param string $bits File content
* @ param string $time Optional . Time formatted in 'yyyy/mm' . Default null .
2020-03-16 14:40:07 -04:00
* @ return array {
* Information about the newly - uploaded file .
*
* @ type string $file Filename of the newly - uploaded file .
* @ type string $url URL of the uploaded file .
* @ type string $type File type .
* @ type string | false $error Error message , if there has been an error .
* }
2008-08-10 12:45:50 -04:00
*/
2008-08-09 00:51:51 -04:00
function wp_upload_bits ( $name , $deprecated , $bits , $time = null ) {
2017-11-30 18:11:00 -05:00
if ( ! empty ( $deprecated ) ) {
2016-07-06 08:40:29 -04:00
_deprecated_argument ( __FUNCTION__ , '2.0.0' );
2017-11-30 18:11:00 -05:00
}
2009-12-30 11:23:39 -05:00
2017-11-30 18:11:00 -05:00
if ( empty ( $name ) ) {
2008-10-21 19:54:18 -04:00
return array ( 'error' => __ ( 'Empty filename' ) );
2017-11-30 18:11:00 -05:00
}
2006-06-21 19:17:19 -04:00
2007-10-11 01:46:57 -04:00
$wp_filetype = wp_check_filetype ( $name );
2017-11-30 18:11:00 -05:00
if ( ! $wp_filetype [ 'ext' ] && ! current_user_can ( 'unfiltered_upload' ) ) {
2021-11-07 18:29:56 -05:00
return array ( 'error' => __ ( 'Sorry, you are not allowed to upload this file type.' ) );
2017-11-30 18:11:00 -05:00
}
2006-06-07 19:17:59 -04:00
2007-12-16 16:34:48 -05:00
$upload = wp_upload_dir ( $time );
2006-06-07 19:17:59 -04:00
2020-02-09 11:55:09 -05:00
if ( false !== $upload [ 'error' ] ) {
2006-06-07 19:17:59 -04:00
return $upload ;
2017-11-30 18:11:00 -05:00
}
2008-02-05 01:47:27 -05:00
2014-04-13 20:20:14 -04:00
/**
2016-05-22 14:36:27 -04:00
* Filters whether to treat the upload bits as an error .
2014-04-13 20:20:14 -04:00
*
2020-06-26 14:49:09 -04:00
* Returning a non - array from the filter will effectively short - circuit preparing the upload bits
* and return that value instead . An error message should be returned as a string .
2014-04-13 20:20:14 -04:00
*
* @ since 3.0 . 0
*
2020-03-01 05:38:07 -05:00
* @ param array | string $upload_bits_error An array of upload bits data , or error message to return .
2014-04-13 20:20:14 -04:00
*/
2017-11-30 18:11:00 -05:00
$upload_bits_error = apply_filters (
2018-08-16 21:51:36 -04:00
'wp_upload_bits' ,
array (
2017-11-30 18:11:00 -05:00
'name' => $name ,
'bits' => $bits ,
'time' => $time ,
)
);
if ( ! is_array ( $upload_bits_error ) ) {
$upload [ 'error' ] = $upload_bits_error ;
2010-01-11 17:08:49 -05:00
return $upload ;
}
2010-01-11 16:49:40 -05:00
2007-12-17 22:32:43 -05:00
$filename = wp_unique_filename ( $upload [ 'path' ], $name );
2006-06-07 19:17:59 -04:00
2007-03-09 15:14:52 -05:00
$new_file = $upload [ 'path' ] . " / $filename " ;
2007-10-11 01:46:57 -04:00
if ( ! wp_mkdir_p ( dirname ( $new_file ) ) ) {
Code Modernization: Replace usage of `strpos()` with `str_starts_with()`.
`str_starts_with()` was introduced in PHP 8.0 to perform a case-sensitive check indicating if the string to search in (haystack) begins with the given substring (needle).
WordPress core includes a polyfill for `str_starts_with()` on PHP < 8.0 as of WordPress 5.9.
This commit replaces `0 === strpos( ... )` with `str_starts_with()` in core files, making the code more readable and consistent, as well as improving performance.
While `strpos()` is slightly faster than the polyfill on PHP < 8.0, `str_starts_with()` is noticeably faster on PHP 8.0+, as it is optimized to avoid unnecessarily searching along the whole haystack if it does not find the needle.
Follow-up to [52039], [52040], [52326].
Props spacedmonkey, costdev, sabernhardt, mukesh27, desrosj, jorbin, TobiasBg, ayeshrajans, lgadzhev, SergeyBiryukov.
Fixes #58012.
Built from https://develop.svn.wordpress.org/trunk@55703
git-svn-id: http://core.svn.wordpress.org/trunk@55215 1a063a9b-81f0-0310-95a4-ce76da25c4cd
2023-05-02 11:45:22 -04:00
if ( str_starts_with ( $upload [ 'basedir' ], ABSPATH ) ) {
2012-10-23 09:49:00 -04:00
$error_path = str_replace ( ABSPATH , '' , $upload [ 'basedir' ] ) . $upload [ 'subdir' ];
2017-11-30 18:11:00 -05:00
} else {
2019-03-01 15:58:52 -05:00
$error_path = wp_basename ( $upload [ 'basedir' ] ) . $upload [ 'subdir' ];
2017-11-30 18:11:00 -05:00
}
2012-10-23 09:49:00 -04:00
2016-08-23 19:48:28 -04:00
$message = sprintf (
2019-09-02 20:41:05 -04:00
/* translators: %s: Directory path. */
2016-08-23 19:48:28 -04:00
__ ( 'Unable to create directory %s. Is its parent directory writable by the server?' ),
$error_path
);
2007-10-11 01:46:57 -04:00
return array ( 'error' => $message );
2006-06-07 19:17:59 -04:00
}
2019-07-09 01:45:58 -04:00
$ifp = @ fopen ( $new_file , 'wb' );
2017-11-30 18:11:00 -05:00
if ( ! $ifp ) {
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 13:13:59 -04:00
return array (
2019-09-02 20:41:05 -04:00
/* translators: %s: File 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 13:13:59 -04:00
'error' => sprintf ( __ ( 'Could not write file %s' ), $new_file ),
);
2017-11-30 18:11:00 -05:00
}
2006-06-07 19:17:59 -04:00
2019-07-09 01:45:58 -04:00
fwrite ( $ifp , $bits );
2007-10-11 01:46:57 -04:00
fclose ( $ifp );
2010-06-02 10:01:21 -04:00
clearstatcache ();
2010-06-02 16:04:07 -04:00
2020-01-28 19:45:18 -05:00
// Set correct file permissions.
2017-11-30 18:11:00 -05:00
$stat = @ stat ( dirname ( $new_file ) );
2006-06-07 19:17:59 -04:00
$perms = $stat [ 'mode' ] & 0007777 ;
$perms = $perms & 0000666 ;
2019-07-09 01:45:58 -04:00
chmod ( $new_file , $perms );
2010-06-02 10:01:21 -04:00
clearstatcache ();
2006-06-07 19:17:59 -04:00
2020-01-28 19:45:18 -05:00
// Compute the URL.
2006-06-07 19:17:59 -04:00
$url = $upload [ 'url' ] . " / $filename " ;
2020-10-19 17:51:06 -04:00
if ( is_multisite () ) {
2020-11-16 17:31:06 -05:00
clean_dirsize_cache ( $new_file );
2020-10-19 17:51:06 -04:00
}
2015-09-17 00:46:25 -04:00
/** This filter is documented in wp-admin/includes/file.php */
2017-11-30 18:11:00 -05:00
return apply_filters (
2018-08-16 21:51:36 -04:00
'wp_handle_upload' ,
array (
2017-11-30 18:11:00 -05:00
'file' => $new_file ,
'url' => $url ,
'type' => $wp_filetype [ 'type' ],
'error' => false ,
2018-08-16 21:51:36 -04:00
),
'sideload'
2017-11-30 18:11:00 -05:00
);
2006-06-07 19:17:59 -04:00
}
2008-08-09 00:51:51 -04:00
/**
2022-08-12 05:53:11 -04:00
* Retrieves the file type based on the extension name .
2008-08-09 00:51:51 -04:00
*
2008-08-10 12:45:50 -04:00
* @ since 2.5 . 0
2008-08-09 00:51:51 -04:00
*
* @ param string $ext The extension to search .
2015-05-25 12:11:25 -04:00
* @ return string | void The file type , example : audio , video , document , spreadsheet , etc .
2008-08-09 00:51:51 -04:00
*/
2008-02-29 01:54:15 -05:00
function wp_ext2type ( $ext ) {
2013-09-14 10:34:09 -04:00
$ext = strtolower ( $ext );
2014-04-13 20:20:14 -04:00
2016-04-12 23:12:27 -04:00
$ext2type = wp_get_ext_types ();
2017-11-30 18:11:00 -05:00
foreach ( $ext2type as $type => $exts ) {
2020-04-04 23:02:11 -04:00
if ( in_array ( $ext , $exts , true ) ) {
2008-02-29 01:54:15 -05:00
return $type ;
2017-11-30 18:11:00 -05:00
}
}
2008-02-29 01:54:15 -05:00
}
2007-10-11 01:46:57 -04:00
2021-08-24 16:52:03 -04:00
/**
* Returns first matched extension for the mime - type ,
* as mapped from wp_get_mime_types () .
*
* @ since 5.8 . 1
*
* @ param string $mime_type
*
* @ return string | false
*/
function wp_get_default_extension_for_mime_type ( $mime_type ) {
$extensions = explode ( '|' , array_search ( $mime_type , wp_get_mime_types (), true ) );
if ( empty ( $extensions [ 0 ] ) ) {
return false ;
}
return $extensions [ 0 ];
}
2008-08-09 00:51:51 -04:00
/**
2022-08-12 05:53:11 -04:00
* Retrieves the file type from the file name .
2008-08-09 00:51:51 -04:00
*
* You can optionally define the mime array , if needed .
*
* @ since 2.0 . 4
*
2023-05-30 15:46:22 -04:00
* @ param string $filename File name or path .
* @ param string [] | null $mimes Optional . Array of allowed mime types keyed by their file extension regex .
* Defaults to the result of get_allowed_mime_types () .
2019-10-26 17:09:04 -04:00
* @ return array {
2019-10-26 19:49:03 -04:00
* Values for the extension and mime type .
2019-10-26 17:09:04 -04:00
*
2019-10-28 15:48:01 -04:00
* @ type string | false $ext File extension , or false if the file doesn ' t match a mime type .
* @ type string | false $type File mime type , or false if the file doesn ' t match a mime type .
2019-10-26 17:09:04 -04:00
* }
2008-08-09 00:51:51 -04:00
*/
2007-10-11 01:46:57 -04:00
function wp_check_filetype ( $filename , $mimes = null ) {
2017-11-30 18:11:00 -05:00
if ( empty ( $mimes ) ) {
2009-11-11 18:07:29 -05:00
$mimes = get_allowed_mime_types ();
2017-11-30 18:11:00 -05:00
}
2009-11-11 18:07:29 -05:00
$type = false ;
2017-11-30 18:11:00 -05:00
$ext = false ;
2009-11-11 18:07:29 -05:00
foreach ( $mimes as $ext_preg => $mime_match ) {
2015-04-20 02:39:25 -04:00
$ext_preg = '!\.(' . $ext_preg . ')$!i' ;
2009-11-11 18:07:29 -05:00
if ( preg_match ( $ext_preg , $filename , $ext_matches ) ) {
$type = $mime_match ;
2017-11-30 18:11:00 -05:00
$ext = $ext_matches [ 1 ];
2009-11-11 18:07:29 -05:00
break ;
}
}
return compact ( 'ext' , 'type' );
}
2010-05-15 00:47:03 -04:00
/**
2022-08-12 05:53:11 -04:00
* Attempts to determine the real file type of a file .
2014-06-30 21:44:15 -04:00
*
2010-05-15 00:47:03 -04:00
* If unable to , the file name extension will be used to determine type .
*
* If it 's determined that the extension does not match the file' s real type ,
* then the " proper_filename " value will be set with a proper filename and extension .
*
2017-01-11 08:08:44 -05:00
* Currently this function only supports renaming images validated via wp_get_image_mime () .
2010-05-15 00:47:03 -04:00
*
* @ since 3.0 . 0
*
2023-05-30 15:46:22 -04:00
* @ param string $file Full path to the file .
* @ param string $filename The name of the file ( may differ from $file due to $file being
* in a tmp directory ) .
* @ param string [] | null $mimes Optional . Array of allowed mime types keyed by their file extension regex .
* Defaults to the result of get_allowed_mime_types () .
2019-10-26 19:49:03 -04:00
* @ return array {
* Values for the extension , mime type , and corrected filename .
*
2019-10-28 15:48:01 -04:00
* @ type string | false $ext File extension , or false if the file doesn ' t match a mime type .
* @ type string | false $type File mime type , or false if the file doesn ' t match a mime type .
* @ type string | false $proper_filename File name with its correct extension , or false if it cannot be determined .
2019-10-26 19:49:03 -04:00
* }
2010-05-15 00:47:03 -04:00
*/
function wp_check_filetype_and_ext ( $file , $filename , $mimes = null ) {
$proper_filename = false ;
2020-01-28 19:45:18 -05:00
// Do basic extension validation and MIME mapping.
2010-05-15 00:47:03 -04:00
$wp_filetype = wp_check_filetype ( $filename , $mimes );
2017-11-30 18:11:00 -05:00
$ext = $wp_filetype [ 'ext' ];
$type = $wp_filetype [ 'type' ];
2010-05-15 00:47:03 -04:00
2020-01-28 19:45:18 -05:00
// We can't do any further validation without a file to work with.
2014-05-15 02:22:14 -04:00
if ( ! file_exists ( $file ) ) {
2010-05-15 00:47:03 -04:00
return compact ( 'ext' , 'type' , 'proper_filename' );
2014-05-15 02:22:14 -04:00
}
2010-05-15 00:47:03 -04:00
2017-02-25 11:08:44 -05:00
$real_mime = false ;
2017-01-11 08:08:44 -05:00
// Validate image types.
Code Modernization: Replace usage of `strpos()` with `str_starts_with()`.
`str_starts_with()` was introduced in PHP 8.0 to perform a case-sensitive check indicating if the string to search in (haystack) begins with the given substring (needle).
WordPress core includes a polyfill for `str_starts_with()` on PHP < 8.0 as of WordPress 5.9.
This commit replaces `0 === strpos( ... )` with `str_starts_with()` in core files, making the code more readable and consistent, as well as improving performance.
While `strpos()` is slightly faster than the polyfill on PHP < 8.0, `str_starts_with()` is noticeably faster on PHP 8.0+, as it is optimized to avoid unnecessarily searching along the whole haystack if it does not find the needle.
Follow-up to [52039], [52040], [52326].
Props spacedmonkey, costdev, sabernhardt, mukesh27, desrosj, jorbin, TobiasBg, ayeshrajans, lgadzhev, SergeyBiryukov.
Fixes #58012.
Built from https://develop.svn.wordpress.org/trunk@55703
git-svn-id: http://core.svn.wordpress.org/trunk@55215 1a063a9b-81f0-0310-95a4-ce76da25c4cd
2023-05-02 11:45:22 -04:00
if ( $type && str_starts_with ( $type , 'image/' ) ) {
2010-05-15 00:47:03 -04:00
2020-01-28 19:45:18 -05:00
// Attempt to figure out what type of image it actually is.
2017-01-11 08:08:44 -05:00
$real_mime = wp_get_image_mime ( $file );
2010-05-15 00:47:03 -04:00
2017-02-25 11:08:44 -05:00
if ( $real_mime && $real_mime != $type ) {
2014-04-13 20:20:14 -04:00
/**
2016-05-22 14:36:27 -04:00
* Filters the list mapping image mime types to their respective extensions .
2014-04-13 20:20:14 -04:00
*
* @ since 3.0 . 0
*
2020-06-20 08:58:10 -04:00
* @ param array $mime_to_ext Array of image mime types and their matching extensions .
2014-04-13 20:20:14 -04:00
*/
2017-11-30 18:11:00 -05:00
$mime_to_ext = apply_filters (
2018-08-16 21:51:36 -04:00
'getimagesize_mimes_to_exts' ,
array (
2017-11-30 18:11:00 -05:00
'image/jpeg' => 'jpg' ,
'image/png' => 'png' ,
'image/gif' => 'gif' ,
'image/bmp' => 'bmp' ,
'image/tiff' => 'tif' ,
Images: enable WebP support.
Add support for uploading, editing and saving WebP images when supported by the server.
Add 'image/webp' to supported mime types. Correctly identify WebP images and sizes even when PHP doesn't support WebP. Resize uploaded WebP files (when supported) and use for front end markup.
Props markoheijne, blobfolio, Clorith, joemcgill, atjn, desrosj, spacedmonkey, marylauc, mikeschroder, hellofromtonya, flixos90.
Fixes #35725.
Built from https://develop.svn.wordpress.org/trunk@50810
git-svn-id: http://core.svn.wordpress.org/trunk@50419 1a063a9b-81f0-0310-95a4-ce76da25c4cd
2021-05-04 10:44:58 -04:00
'image/webp' => 'webp' ,
2017-11-30 18:11:00 -05:00
)
);
2010-05-15 00:47:03 -04:00
2020-01-28 19:45:18 -05:00
// Replace whatever is after the last period in the filename with the correct extension.
2017-01-11 08:08:44 -05:00
if ( ! empty ( $mime_to_ext [ $real_mime ] ) ) {
2010-05-15 00:47:03 -04:00
$filename_parts = explode ( '.' , $filename );
array_pop ( $filename_parts );
2017-01-11 08:08:44 -05:00
$filename_parts [] = $mime_to_ext [ $real_mime ];
2017-11-30 18:11:00 -05:00
$new_filename = implode ( '.' , $filename_parts );
2010-05-15 00:47:03 -04:00
2014-05-15 02:22:14 -04:00
if ( $new_filename != $filename ) {
2020-01-28 19:45:18 -05:00
$proper_filename = $new_filename ; // Mark that it changed.
2014-05-15 02:22:14 -04:00
}
2020-01-28 19:45:18 -05:00
// Redefine the extension / MIME.
2010-05-15 00:47:03 -04:00
$wp_filetype = wp_check_filetype ( $new_filename , $mimes );
2017-11-30 18:11:00 -05:00
$ext = $wp_filetype [ 'ext' ];
$type = $wp_filetype [ 'type' ];
2017-01-11 08:08:44 -05:00
} else {
2017-02-25 11:08:44 -05:00
// Reset $real_mime and try validating again.
$real_mime = false ;
2010-05-15 00:47:03 -04:00
}
}
2017-02-25 11:08:44 -05:00
}
// Validate files that didn't get validated during previous checks.
if ( $type && ! $real_mime && extension_loaded ( 'fileinfo' ) ) {
2017-11-30 18:11:00 -05:00
$finfo = finfo_open ( FILEINFO_MIME_TYPE );
2017-01-11 08:08:44 -05:00
$real_mime = finfo_file ( $finfo , $file );
finfo_close ( $finfo );
2020-01-28 19:45:18 -05:00
// fileinfo often misidentifies obscure files as one of these types.
2018-12-18 11:35:49 -05:00
$nonspecific_types = array (
'application/octet-stream' ,
'application/encrypted' ,
'application/CDFV2-encrypted' ,
'application/zip' ,
);
2017-02-25 11:08:44 -05:00
/*
2018-12-18 11:35:49 -05:00
* If $real_mime doesn 't match the content type we' re expecting from the file ' s extension ,
* we need to do some additional vetting . Media types and those listed in $nonspecific_types are
* allowed some leeway , but anything else must exactly match the real content type .
2017-02-25 11:08:44 -05:00
*/
2018-12-18 11:35:49 -05:00
if ( in_array ( $real_mime , $nonspecific_types , true ) ) {
// File is a non-specific binary type. That's ok if it's a type that generally tends to be binary.
2020-04-04 23:02:11 -04:00
if ( ! in_array ( substr ( $type , 0 , strcspn ( $type , '/' ) ), array ( 'application' , 'video' , 'audio' ), true ) ) {
2019-07-02 19:42:58 -04:00
$type = false ;
$ext = false ;
2018-12-18 11:35:49 -05:00
}
Code Modernization: Replace usage of `strpos()` with `str_starts_with()`.
`str_starts_with()` was introduced in PHP 8.0 to perform a case-sensitive check indicating if the string to search in (haystack) begins with the given substring (needle).
WordPress core includes a polyfill for `str_starts_with()` on PHP < 8.0 as of WordPress 5.9.
This commit replaces `0 === strpos( ... )` with `str_starts_with()` in core files, making the code more readable and consistent, as well as improving performance.
While `strpos()` is slightly faster than the polyfill on PHP < 8.0, `str_starts_with()` is noticeably faster on PHP 8.0+, as it is optimized to avoid unnecessarily searching along the whole haystack if it does not find the needle.
Follow-up to [52039], [52040], [52326].
Props spacedmonkey, costdev, sabernhardt, mukesh27, desrosj, jorbin, TobiasBg, ayeshrajans, lgadzhev, SergeyBiryukov.
Fixes #58012.
Built from https://develop.svn.wordpress.org/trunk@55703
git-svn-id: http://core.svn.wordpress.org/trunk@55215 1a063a9b-81f0-0310-95a4-ce76da25c4cd
2023-05-02 11:45:22 -04:00
} elseif ( str_starts_with ( $real_mime , 'video/' ) || str_starts_with ( $real_mime , 'audio/' ) ) {
2018-12-18 11:35:49 -05:00
/*
* For these types , only the major type must match the real value .
* This means that common mismatches are forgiven : application / vnd . apple . numbers is often misidentified as application / zip ,
* and some media files are commonly named with the wrong extension ( . mov instead of . mp4 )
*/
if ( substr ( $real_mime , 0 , strcspn ( $real_mime , '/' ) ) !== substr ( $type , 0 , strcspn ( $type , '/' ) ) ) {
2019-07-02 19:42:58 -04:00
$type = false ;
$ext = false ;
2017-02-25 11:08:44 -05:00
}
2019-01-07 15:48:51 -05:00
} elseif ( 'text/plain' === $real_mime ) {
// A few common file types are occasionally detected as text/plain; allow those.
2019-01-07 16:09:49 -05:00
if ( ! in_array (
$type ,
array (
2019-01-07 15:48:51 -05:00
'text/plain' ,
'text/csv' ,
2020-09-25 21:11:09 -04:00
'application/csv' ,
2019-01-07 15:48:51 -05:00
'text/richtext' ,
'text/tsv' ,
'text/vtt' ,
2020-04-04 23:02:11 -04:00
),
true
2019-01-07 16:09:49 -05:00
)
2019-01-07 15:48:51 -05:00
) {
2019-07-02 19:42:58 -04:00
$type = false ;
$ext = false ;
2019-01-07 15:48:51 -05:00
}
2020-09-25 21:11:09 -04:00
} elseif ( 'application/csv' === $real_mime ) {
// Special casing for CSV files.
if ( ! in_array (
$type ,
array (
'text/csv' ,
'text/plain' ,
'application/csv' ,
),
true
)
) {
$type = false ;
$ext = false ;
}
2019-01-07 16:09:49 -05:00
} elseif ( 'text/rtf' === $real_mime ) {
2019-01-07 15:48:51 -05:00
// Special casing for RTF files.
2019-01-07 16:09:49 -05:00
if ( ! in_array (
$type ,
array (
2019-01-07 15:48:51 -05:00
'text/rtf' ,
'text/plain' ,
'application/rtf' ,
2020-04-04 23:02:11 -04:00
),
true
2019-01-07 16:09:49 -05:00
)
2019-01-07 15:48:51 -05:00
) {
2019-07-02 19:42:58 -04:00
$type = false ;
$ext = false ;
2019-01-07 15:48:51 -05:00
}
2018-12-18 11:35:49 -05:00
} else {
if ( $type !== $real_mime ) {
/*
* Everything else including image /* and application /*:
* If the real content type doesn 't match the file extension, assume it' s dangerous .
*/
2019-07-02 19:42:58 -04:00
$type = false ;
$ext = false ;
2018-12-18 11:35:49 -05:00
}
}
}
2020-01-28 19:45:18 -05:00
// The mime type must be allowed.
2018-12-18 11:35:49 -05:00
if ( $type ) {
$allowed = get_allowed_mime_types ();
2020-04-04 23:02:11 -04:00
if ( ! in_array ( $type , $allowed , true ) ) {
2019-07-02 19:42:58 -04:00
$type = false ;
$ext = false ;
2017-01-11 08:08:44 -05:00
}
2010-05-15 00:47:03 -04:00
}
2014-04-13 20:20:14 -04:00
/**
2016-05-22 14:36:27 -04:00
* Filters the " real " file type of the given file .
2014-04-13 20:20:14 -04:00
*
* @ since 3.0 . 0
2019-01-21 16:52:50 -05:00
* @ since 5.1 . 0 The $real_mime parameter was added .
2014-04-13 20:20:14 -04:00
*
2023-05-30 15:46:22 -04:00
* @ param array $wp_check_filetype_and_ext {
2019-10-26 19:49:03 -04:00
* Values for the extension , mime type , and corrected filename .
*
2019-10-28 15:48:01 -04:00
* @ type string | false $ext File extension , or false if the file doesn ' t match a mime type .
* @ type string | false $type File mime type , or false if the file doesn ' t match a mime type .
* @ type string | false $proper_filename File name with its correct extension , or false if it cannot be determined .
2019-10-26 19:49:03 -04:00
* }
2023-05-30 15:46:22 -04:00
* @ param string $file Full path to the file .
* @ param string $filename The name of the file ( may differ from $file due to
* $file being in a tmp directory ) .
* @ param string [] | null $mimes Array of mime types keyed by their file extension regex , or null if
* none were provided .
* @ param string | false $real_mime The actual mime type or false if the type cannot be determined .
2014-04-13 20:20:14 -04:00
*/
2019-01-21 16:52:50 -05:00
return apply_filters ( 'wp_check_filetype_and_ext' , compact ( 'ext' , 'type' , 'proper_filename' ), $file , $filename , $mimes , $real_mime );
2010-05-15 00:47:03 -04:00
}
2017-01-11 08:08:44 -05:00
/**
* Returns the real mime type of an image file .
*
* This depends on exif_imagetype () or getimagesize () to determine real mime types .
*
* @ since 4.7 . 1
2021-05-07 05:33:01 -04:00
* @ since 5.8 . 0 Added support for WebP images .
2017-01-11 08:08:44 -05:00
*
* @ param string $file Full path to the file .
* @ return string | false The actual mime type or false if the type cannot be determined .
*/
function wp_get_image_mime ( $file ) {
/*
* Use exif_imagetype () to check the mimetype if available or fall back to
2022-02-12 09:45:00 -05:00
* getimagesize () if exif isn ' t available . If either function throws an Exception
2017-01-11 08:08:44 -05:00
* we assume the file could not be validated .
*/
try {
2017-01-11 11:36:39 -05:00
if ( is_callable ( 'exif_imagetype' ) ) {
2017-04-09 18:44:43 -04:00
$imagetype = exif_imagetype ( $file );
2017-11-30 18:11:00 -05:00
$mime = ( $imagetype ) ? image_type_to_mime_type ( $imagetype ) : false ;
2017-01-11 08:08:44 -05:00
} elseif ( function_exists ( 'getimagesize' ) ) {
2021-05-07 05:33:01 -04:00
// Don't silence errors when in debug mode, unless running unit tests.
if ( defined ( 'WP_DEBUG' ) && WP_DEBUG
&& ! defined ( 'WP_RUN_CORE_TESTS' )
) {
// Not using wp_getimagesize() here to avoid an infinite loop.
$imagesize = getimagesize ( $file );
} else {
// phpcs:ignore WordPress.PHP.NoSilencedErrors
$imagesize = @ getimagesize ( $file );
}
$mime = ( isset ( $imagesize [ 'mime' ] ) ) ? $imagesize [ 'mime' ] : false ;
2017-01-11 08:08:44 -05:00
} else {
$mime = false ;
}
Images: enable WebP support.
Add support for uploading, editing and saving WebP images when supported by the server.
Add 'image/webp' to supported mime types. Correctly identify WebP images and sizes even when PHP doesn't support WebP. Resize uploaded WebP files (when supported) and use for front end markup.
Props markoheijne, blobfolio, Clorith, joemcgill, atjn, desrosj, spacedmonkey, marylauc, mikeschroder, hellofromtonya, flixos90.
Fixes #35725.
Built from https://develop.svn.wordpress.org/trunk@50810
git-svn-id: http://core.svn.wordpress.org/trunk@50419 1a063a9b-81f0-0310-95a4-ce76da25c4cd
2021-05-04 10:44:58 -04:00
if ( false !== $mime ) {
return $mime ;
}
2022-02-11 10:50:05 -05:00
$magic = file_get_contents ( $file , false , null , 0 , 12 );
Images: enable WebP support.
Add support for uploading, editing and saving WebP images when supported by the server.
Add 'image/webp' to supported mime types. Correctly identify WebP images and sizes even when PHP doesn't support WebP. Resize uploaded WebP files (when supported) and use for front end markup.
Props markoheijne, blobfolio, Clorith, joemcgill, atjn, desrosj, spacedmonkey, marylauc, mikeschroder, hellofromtonya, flixos90.
Fixes #35725.
Built from https://develop.svn.wordpress.org/trunk@50810
git-svn-id: http://core.svn.wordpress.org/trunk@50419 1a063a9b-81f0-0310-95a4-ce76da25c4cd
2021-05-04 10:44:58 -04:00
if ( false === $magic ) {
return false ;
}
2021-05-05 13:08:01 -04:00
/*
* Add WebP fallback detection when image library doesn ' t support WebP .
* Note : detection values come from LibWebP , see
* https :// github . com / webmproject / libwebp / blob / master / imageio / image_dec . c #L30
*/
Images: enable WebP support.
Add support for uploading, editing and saving WebP images when supported by the server.
Add 'image/webp' to supported mime types. Correctly identify WebP images and sizes even when PHP doesn't support WebP. Resize uploaded WebP files (when supported) and use for front end markup.
Props markoheijne, blobfolio, Clorith, joemcgill, atjn, desrosj, spacedmonkey, marylauc, mikeschroder, hellofromtonya, flixos90.
Fixes #35725.
Built from https://develop.svn.wordpress.org/trunk@50810
git-svn-id: http://core.svn.wordpress.org/trunk@50419 1a063a9b-81f0-0310-95a4-ce76da25c4cd
2021-05-04 10:44:58 -04:00
$magic = bin2hex ( $magic );
if (
// RIFF.
Code Modernization: Replace usage of `strpos()` with `str_starts_with()`.
`str_starts_with()` was introduced in PHP 8.0 to perform a case-sensitive check indicating if the string to search in (haystack) begins with the given substring (needle).
WordPress core includes a polyfill for `str_starts_with()` on PHP < 8.0 as of WordPress 5.9.
This commit replaces `0 === strpos( ... )` with `str_starts_with()` in core files, making the code more readable and consistent, as well as improving performance.
While `strpos()` is slightly faster than the polyfill on PHP < 8.0, `str_starts_with()` is noticeably faster on PHP 8.0+, as it is optimized to avoid unnecessarily searching along the whole haystack if it does not find the needle.
Follow-up to [52039], [52040], [52326].
Props spacedmonkey, costdev, sabernhardt, mukesh27, desrosj, jorbin, TobiasBg, ayeshrajans, lgadzhev, SergeyBiryukov.
Fixes #58012.
Built from https://develop.svn.wordpress.org/trunk@55703
git-svn-id: http://core.svn.wordpress.org/trunk@55215 1a063a9b-81f0-0310-95a4-ce76da25c4cd
2023-05-02 11:45:22 -04:00
( str_starts_with ( $magic , '52494646' ) ) &&
Images: enable WebP support.
Add support for uploading, editing and saving WebP images when supported by the server.
Add 'image/webp' to supported mime types. Correctly identify WebP images and sizes even when PHP doesn't support WebP. Resize uploaded WebP files (when supported) and use for front end markup.
Props markoheijne, blobfolio, Clorith, joemcgill, atjn, desrosj, spacedmonkey, marylauc, mikeschroder, hellofromtonya, flixos90.
Fixes #35725.
Built from https://develop.svn.wordpress.org/trunk@50810
git-svn-id: http://core.svn.wordpress.org/trunk@50419 1a063a9b-81f0-0310-95a4-ce76da25c4cd
2021-05-04 10:44:58 -04:00
// WEBP.
( 16 === strpos ( $magic , '57454250' ) )
) {
$mime = 'image/webp' ;
}
2017-01-11 08:08:44 -05:00
} catch ( Exception $e ) {
$mime = false ;
}
return $mime ;
}
2012-08-17 13:25:19 -04:00
/**
2022-08-12 05:53:11 -04:00
* Retrieves the list of mime types and file extensions .
2012-08-17 13:25:19 -04:00
*
* @ since 3.5 . 0
2019-10-26 16:43:04 -04:00
* @ since 4.2 . 0 Support was added for GIMP ( . xcf ) files .
* @ since 4.9 . 2 Support was added for Flac ( . flac ) files .
* @ since 4.9 . 6 Support was added for AAC ( . aac ) files .
2012-08-17 13:25:19 -04:00
*
2019-10-26 17:09:04 -04:00
* @ return string [] Array of mime types keyed by the file extension regex corresponding to those types .
2012-08-17 13:25:19 -04:00
*/
function wp_get_mime_types () {
2014-04-13 20:20:14 -04:00
/**
2016-05-22 14:36:27 -04:00
* Filters the list of mime types and file extensions .
2014-04-13 20:20:14 -04:00
*
* This filter should be used to add , not remove , mime types . To remove
2016-05-23 15:01:27 -04:00
* mime types , use the { @ see 'upload_mimes' } filter .
2014-04-13 20:20:14 -04:00
*
* @ since 3.5 . 0
*
2019-10-26 17:09:04 -04:00
* @ param string [] $wp_get_mime_types Mime types keyed by the file extension regex
Docs: Update various DocBlocks and inline comments per the documentation standards.
Includes minor formatting edits for consistency.
Follow-up to [53/tests], [12179], [12946], [35288], [37884], [38810], [38928], [46596], [48131], [52955], [53548], [53813], [53873], [54118], [54316], [54420], [54421], [54803].
See #56792.
Built from https://develop.svn.wordpress.org/trunk@54855
git-svn-id: http://core.svn.wordpress.org/trunk@54407 1a063a9b-81f0-0310-95a4-ce76da25c4cd
2022-11-17 13:15:19 -05:00
* corresponding to those types .
2014-04-13 20:20:14 -04:00
*/
2017-11-30 18:11:00 -05:00
return apply_filters (
2018-08-16 21:51:36 -04:00
'mime_types' ,
array (
2017-11-30 18:11:00 -05:00
// Image formats.
'jpg|jpeg|jpe' => 'image/jpeg' ,
'gif' => 'image/gif' ,
'png' => 'image/png' ,
'bmp' => 'image/bmp' ,
'tiff|tif' => 'image/tiff' ,
Images: enable WebP support.
Add support for uploading, editing and saving WebP images when supported by the server.
Add 'image/webp' to supported mime types. Correctly identify WebP images and sizes even when PHP doesn't support WebP. Resize uploaded WebP files (when supported) and use for front end markup.
Props markoheijne, blobfolio, Clorith, joemcgill, atjn, desrosj, spacedmonkey, marylauc, mikeschroder, hellofromtonya, flixos90.
Fixes #35725.
Built from https://develop.svn.wordpress.org/trunk@50810
git-svn-id: http://core.svn.wordpress.org/trunk@50419 1a063a9b-81f0-0310-95a4-ce76da25c4cd
2021-05-04 10:44:58 -04:00
'webp' => 'image/webp' ,
2017-11-30 18:11:00 -05:00
'ico' => 'image/x-icon' ,
2020-07-03 19:15:03 -04:00
'heic' => 'image/heic' ,
2017-11-30 18:11:00 -05:00
// Video formats.
'asf|asx' => 'video/x-ms-asf' ,
'wmv' => 'video/x-ms-wmv' ,
'wmx' => 'video/x-ms-wmx' ,
'wm' => 'video/x-ms-wm' ,
'avi' => 'video/avi' ,
'divx' => 'video/divx' ,
'flv' => 'video/x-flv' ,
'mov|qt' => 'video/quicktime' ,
'mpeg|mpg|mpe' => 'video/mpeg' ,
'mp4|m4v' => 'video/mp4' ,
'ogv' => 'video/ogg' ,
'webm' => 'video/webm' ,
'mkv' => 'video/x-matroska' ,
2020-01-28 19:45:18 -05:00
'3gp|3gpp' => 'video/3gpp' , // Can also be audio.
'3g2|3gp2' => 'video/3gpp2' , // Can also be audio.
2017-11-30 18:11:00 -05:00
// Text formats.
'txt|asc|c|cc|h|srt' => 'text/plain' ,
'csv' => 'text/csv' ,
'tsv' => 'text/tab-separated-values' ,
'ics' => 'text/calendar' ,
'rtx' => 'text/richtext' ,
'css' => 'text/css' ,
'htm|html' => 'text/html' ,
'vtt' => 'text/vtt' ,
'dfxp' => 'application/ttaf+xml' ,
// Audio formats.
'mp3|m4a|m4b' => 'audio/mpeg' ,
2018-02-11 11:40:31 -05:00
'aac' => 'audio/aac' ,
2017-11-30 18:11:00 -05:00
'ra|ram' => 'audio/x-realaudio' ,
'wav' => 'audio/wav' ,
'ogg|oga' => 'audio/ogg' ,
2018-01-15 17:17:47 -05:00
'flac' => 'audio/flac' ,
2017-11-30 18:11:00 -05:00
'mid|midi' => 'audio/midi' ,
'wma' => 'audio/x-ms-wma' ,
'wax' => 'audio/x-ms-wax' ,
'mka' => 'audio/x-matroska' ,
// Misc application formats.
'rtf' => 'application/rtf' ,
'js' => 'application/javascript' ,
'pdf' => 'application/pdf' ,
'swf' => 'application/x-shockwave-flash' ,
'class' => 'application/java' ,
'tar' => 'application/x-tar' ,
'zip' => 'application/zip' ,
'gz|gzip' => 'application/x-gzip' ,
'rar' => 'application/rar' ,
'7z' => 'application/x-7z-compressed' ,
'exe' => 'application/x-msdownload' ,
'psd' => 'application/octet-stream' ,
'xcf' => 'application/octet-stream' ,
// MS Office formats.
'doc' => 'application/msword' ,
'pot|pps|ppt' => 'application/vnd.ms-powerpoint' ,
'wri' => 'application/vnd.ms-write' ,
'xla|xls|xlt|xlw' => 'application/vnd.ms-excel' ,
'mdb' => 'application/vnd.ms-access' ,
'mpp' => 'application/vnd.ms-project' ,
'docx' => 'application/vnd.openxmlformats-officedocument.wordprocessingml.document' ,
'docm' => 'application/vnd.ms-word.document.macroEnabled.12' ,
'dotx' => 'application/vnd.openxmlformats-officedocument.wordprocessingml.template' ,
'dotm' => 'application/vnd.ms-word.template.macroEnabled.12' ,
'xlsx' => 'application/vnd.openxmlformats-officedocument.spreadsheetml.sheet' ,
'xlsm' => 'application/vnd.ms-excel.sheet.macroEnabled.12' ,
'xlsb' => 'application/vnd.ms-excel.sheet.binary.macroEnabled.12' ,
'xltx' => 'application/vnd.openxmlformats-officedocument.spreadsheetml.template' ,
'xltm' => 'application/vnd.ms-excel.template.macroEnabled.12' ,
'xlam' => 'application/vnd.ms-excel.addin.macroEnabled.12' ,
'pptx' => 'application/vnd.openxmlformats-officedocument.presentationml.presentation' ,
'pptm' => 'application/vnd.ms-powerpoint.presentation.macroEnabled.12' ,
'ppsx' => 'application/vnd.openxmlformats-officedocument.presentationml.slideshow' ,
'ppsm' => 'application/vnd.ms-powerpoint.slideshow.macroEnabled.12' ,
'potx' => 'application/vnd.openxmlformats-officedocument.presentationml.template' ,
'potm' => 'application/vnd.ms-powerpoint.template.macroEnabled.12' ,
'ppam' => 'application/vnd.ms-powerpoint.addin.macroEnabled.12' ,
'sldx' => 'application/vnd.openxmlformats-officedocument.presentationml.slide' ,
'sldm' => 'application/vnd.ms-powerpoint.slide.macroEnabled.12' ,
'onetoc|onetoc2|onetmp|onepkg' => 'application/onenote' ,
'oxps' => 'application/oxps' ,
'xps' => 'application/vnd.ms-xpsdocument' ,
// OpenOffice formats.
'odt' => 'application/vnd.oasis.opendocument.text' ,
'odp' => 'application/vnd.oasis.opendocument.presentation' ,
'ods' => 'application/vnd.oasis.opendocument.spreadsheet' ,
'odg' => 'application/vnd.oasis.opendocument.graphics' ,
'odc' => 'application/vnd.oasis.opendocument.chart' ,
'odb' => 'application/vnd.oasis.opendocument.database' ,
'odf' => 'application/vnd.oasis.opendocument.formula' ,
// WordPerfect formats.
'wp|wpd' => 'application/wordperfect' ,
// iWork formats.
'key' => 'application/vnd.apple.keynote' ,
'numbers' => 'application/vnd.apple.numbers' ,
'pages' => 'application/vnd.apple.pages' ,
)
);
2012-08-17 13:25:19 -04:00
}
2016-04-12 23:12:27 -04:00
/**
2016-07-20 12:57:32 -04:00
* Retrieves the list of common file extensions and their types .
2016-04-12 23:12:27 -04:00
*
* @ since 4.6 . 0
*
2019-11-05 16:23:02 -05:00
* @ return array [] Multi - dimensional array of file extensions types keyed by the type of file .
2016-04-12 23:12:27 -04:00
*/
function wp_get_ext_types () {
/**
2016-05-22 14:36:27 -04:00
* Filters file type based on the extension name .
2016-04-12 23:12:27 -04:00
*
* @ since 2.5 . 0
*
* @ see wp_ext2type ()
*
2019-11-05 16:23:02 -05:00
* @ param array [] $ext2type Multi - dimensional array of file extensions types keyed by the type of file .
2016-04-12 23:12:27 -04:00
*/
2017-11-30 18:11:00 -05:00
return apply_filters (
2018-08-16 21:51:36 -04:00
'ext2type' ,
array (
Images: enable WebP support.
Add support for uploading, editing and saving WebP images when supported by the server.
Add 'image/webp' to supported mime types. Correctly identify WebP images and sizes even when PHP doesn't support WebP. Resize uploaded WebP files (when supported) and use for front end markup.
Props markoheijne, blobfolio, Clorith, joemcgill, atjn, desrosj, spacedmonkey, marylauc, mikeschroder, hellofromtonya, flixos90.
Fixes #35725.
Built from https://develop.svn.wordpress.org/trunk@50810
git-svn-id: http://core.svn.wordpress.org/trunk@50419 1a063a9b-81f0-0310-95a4-ce76da25c4cd
2021-05-04 10:44:58 -04:00
'image' => array ( 'jpg' , 'jpeg' , 'jpe' , 'gif' , 'png' , 'bmp' , 'tif' , 'tiff' , 'ico' , 'heic' , 'webp' ),
2018-01-15 17:17:47 -05:00
'audio' => array ( 'aac' , 'ac3' , 'aif' , 'aiff' , 'flac' , 'm3a' , 'm4a' , 'm4b' , 'mka' , 'mp1' , 'mp2' , 'mp3' , 'ogg' , 'oga' , 'ram' , 'wav' , 'wma' ),
2017-11-30 18:11:00 -05:00
'video' => array ( '3g2' , '3gp' , '3gpp' , 'asf' , 'avi' , 'divx' , 'dv' , 'flv' , 'm4v' , 'mkv' , 'mov' , 'mp4' , 'mpeg' , 'mpg' , 'mpv' , 'ogm' , 'ogv' , 'qt' , 'rm' , 'vob' , 'wmv' ),
'document' => array ( 'doc' , 'docx' , 'docm' , 'dotm' , 'odt' , 'pages' , 'pdf' , 'xps' , 'oxps' , 'rtf' , 'wp' , 'wpd' , 'psd' , 'xcf' ),
'spreadsheet' => array ( 'numbers' , 'ods' , 'xls' , 'xlsx' , 'xlsm' , 'xlsb' ),
'interactive' => array ( 'swf' , 'key' , 'ppt' , 'pptx' , 'pptm' , 'pps' , 'ppsx' , 'ppsm' , 'sldx' , 'sldm' , 'odp' ),
'text' => array ( 'asc' , 'csv' , 'tsv' , 'txt' ),
'archive' => array ( 'bz2' , 'cab' , 'dmg' , 'gz' , 'rar' , 'sea' , 'sit' , 'sqx' , 'tar' , 'tgz' , 'zip' , '7z' ),
'code' => array ( 'css' , 'htm' , 'html' , 'php' , 'js' ),
)
);
2016-04-12 23:12:27 -04:00
}
2022-03-14 12:32:06 -04:00
/**
* Wrapper for PHP filesize with filters and casting the result as an integer .
*
* @ since 6.0 . 0
*
* @ link https :// www . php . net / manual / en / function . filesize . php
*
* @ param string $path Path to the file .
* @ return int The size of the file in bytes , or 0 in the event of an error .
*/
function wp_filesize ( $path ) {
/**
* Filters the result of wp_filesize before the PHP function is run .
*
* @ since 6.0 . 0
*
* @ param null | int $size The unfiltered value . Returning an int from the callback bypasses the filesize call .
* @ param string $path Path to the file .
*/
$size = apply_filters ( 'pre_wp_filesize' , null , $path );
if ( is_int ( $size ) ) {
return $size ;
}
2022-05-10 01:02:11 -04:00
$size = file_exists ( $path ) ? ( int ) filesize ( $path ) : 0 ;
2022-03-14 12:32:06 -04:00
/**
* Filters the size of the file .
*
* @ since 6.0 . 0
*
* @ param int $size The result of PHP filesize on the file .
* @ param string $path Path to the file .
*/
return ( int ) apply_filters ( 'wp_filesize' , $size , $path );
}
2009-11-11 18:07:29 -05:00
/**
2022-08-12 05:53:11 -04:00
* Retrieves the list of allowed mime types and file extensions .
2009-11-11 18:07:29 -05:00
*
* @ since 2.8 . 6
2012-06-29 11:16:36 -04:00
*
2013-09-10 14:04:09 -04:00
* @ param int | WP_User $user Optional . User to check . Defaults to current user .
2019-10-26 17:09:04 -04:00
* @ return string [] Array of mime types keyed by the file extension regex corresponding
* to those types .
2009-11-11 18:07:29 -05:00
*/
2013-09-10 14:04:09 -04:00
function get_allowed_mime_types ( $user = null ) {
$t = wp_get_mime_types ();
unset ( $t [ 'swf' ], $t [ 'exe' ] );
2017-11-30 18:11:00 -05:00
if ( function_exists ( 'current_user_can' ) ) {
2013-09-11 00:49:10 -04:00
$unfiltered = $user ? user_can ( $user , 'unfiltered_html' ) : current_user_can ( 'unfiltered_html' );
2017-11-30 18:11:00 -05:00
}
2013-09-11 00:49:10 -04:00
2017-11-29 11:00:48 -05:00
if ( empty ( $unfiltered ) ) {
unset ( $t [ 'htm|html' ], $t [ 'js' ] );
}
2013-09-10 14:04:09 -04:00
2014-04-13 20:20:14 -04:00
/**
2022-08-12 05:53:11 -04:00
* Filters the list of allowed mime types and file extensions .
2014-04-13 20:20:14 -04:00
*
* @ since 2.0 . 0
*
2019-10-26 16:43:04 -04:00
* @ param array $t Mime types keyed by the file extension regex corresponding to those types .
2014-04-13 20:20:14 -04:00
* @ param int | WP_User | null $user User ID , User object or null if not provided ( indicates current user ) .
*/
2013-09-10 14:04:09 -04:00
return apply_filters ( 'upload_mimes' , $t , $user );
2006-06-21 19:17:19 -04:00
}
2009-11-12 00:20:48 -05:00
2008-08-09 00:51:51 -04:00
/**
2022-08-12 05:53:11 -04:00
* Displays " Are You Sure " message to confirm the action being taken .
2008-08-09 00:51:51 -04:00
*
2014-06-30 21:44:15 -04:00
* If the action has the nonce explain message , then it will be displayed
* along with the " Are you sure? " message .
2008-08-09 00:51:51 -04:00
*
* @ since 2.0 . 4
*
* @ param string $action The nonce action .
*/
2007-10-11 01:46:57 -04:00
function wp_nonce_ays ( $action ) {
2021-11-09 18:09:00 -05:00
// Default title and response code.
$title = __ ( 'Something went wrong.' );
$response_code = 403 ;
2020-05-16 14:42:12 -04:00
if ( 'log-out' === $action ) {
2021-11-09 18:09:00 -05:00
$title = sprintf (
2019-09-02 20:41:05 -04:00
/* translators: %s: Site title. */
2016-08-23 19:48:28 -04:00
__ ( 'You are attempting to log out of %s' ),
get_bloginfo ( 'name' )
);
2022-11-05 18:03:16 -04:00
2014-02-25 15:02:14 -05:00
$redirect_to = isset ( $_REQUEST [ 'redirect_to' ] ) ? $_REQUEST [ 'redirect_to' ] : '' ;
2022-11-05 18:03:16 -04:00
$html = $title ;
$html .= '</p><p>' ;
$html .= sprintf (
2019-09-02 20:41:05 -04:00
/* translators: %s: Logout URL. */
2016-08-23 19:48:28 -04:00
__ ( 'Do you really want to <a href="%s">log out</a>?' ),
wp_logout_url ( $redirect_to )
);
2012-06-26 02:10:07 -04:00
} else {
2018-02-18 21:13:32 -05:00
$html = __ ( 'The link you followed has expired.' );
2022-11-05 18:03:16 -04:00
2016-08-23 19:48:28 -04:00
if ( wp_get_referer () ) {
2022-10-17 07:04:12 -04:00
$wp_http_referer = remove_query_arg ( 'updated' , wp_get_referer () );
$wp_http_referer = wp_validate_redirect ( esc_url_raw ( $wp_http_referer ) );
2022-11-05 18:03:16 -04:00
2016-08-23 19:48:28 -04:00
$html .= '</p><p>' ;
2017-11-30 18:11:00 -05:00
$html .= sprintf (
'<a href="%s">%s</a>' ,
2022-10-17 07:04:12 -04:00
esc_url ( $wp_http_referer ),
2016-08-23 19:48:28 -04:00
__ ( 'Please try again.' )
);
}
2012-06-26 02:10:07 -04:00
}
2008-09-28 17:05:37 -04:00
2021-11-09 18:09:00 -05:00
wp_die ( $html , $title , $response_code );
2006-06-27 04:06:00 -04:00
}
2008-08-09 00:51:51 -04:00
/**
2019-03-16 21:45:50 -04:00
* Kills WordPress execution and displays HTML page with an error message .
2008-08-09 00:51:51 -04:00
*
2014-11-18 11:47:23 -05:00
* This function complements the `die()` PHP function . The difference is that
2008-08-09 00:51:51 -04:00
* HTML will be displayed to the user . It is recommended to use this function
2014-11-18 11:47:23 -05:00
* only when the execution should not continue any further . It is not recommended
* to call this function very often , and try to handle as many errors as possible
* silently or more gracefully .
2014-11-16 01:11:22 -05:00
*
* As a shorthand , the desired HTTP response code may be passed as an integer to
2014-11-18 11:47:23 -05:00
* the `$title` parameter ( the default title would apply ) or the `$args` parameter .
2008-08-09 00:51:51 -04:00
*
* @ since 2.0 . 4
2014-11-21 12:08:23 -05:00
* @ since 4.1 . 0 The `$title` and `$args` parameters were changed to optionally accept
* an integer to be used as the response code .
2019-01-21 17:52:51 -05:00
* @ since 5.1 . 0 The `$link_url` , `$link_text` , and `$exit` arguments were added .
2019-09-14 11:42:56 -04:00
* @ since 5.3 . 0 The `$charset` argument was added .
2020-07-25 11:26:05 -04:00
* @ since 5.5 . 0 The `$text_direction` argument has a priority over get_language_attributes ()
* in the default handler .
2008-08-09 00:51:51 -04:00
*
2019-08-03 21:59:56 -04:00
* @ global WP_Query $wp_query WordPress Query object .
2019-04-15 19:49:53 -04:00
*
2016-05-02 00:00:28 -04:00
* @ param string | WP_Error $message Optional . Error message . If this is a WP_Error object ,
2016-09-03 23:41:31 -04:00
* and not an Ajax or XML - RPC request , the error ' s messages are used .
2023-02-21 11:39:19 -05:00
* Default empty string .
2014-11-18 11:47:23 -05:00
* @ param string | int $title Optional . Error title . If `$message` is a `WP_Error` object ,
* error data with the key 'title' may be used to specify the title .
2023-02-21 11:39:19 -05:00
* If `$title` is an integer , then it is treated as the response code .
* Default empty string .
2014-11-16 01:11:22 -05:00
* @ param string | array | int $args {
2014-11-18 11:47:23 -05:00
* Optional . Arguments to control behavior . If `$args` is an integer , then it is treated
* as the response code . Default empty array .
2014-11-16 01:11:22 -05:00
*
2016-10-24 09:13:58 -04:00
* @ type int $response The HTTP response code . Default 200 for Ajax requests , 500 otherwise .
2019-01-16 10:21:50 -05:00
* @ type string $link_url A URL to include a link to . Only works in combination with $link_text .
* Default empty string .
* @ type string $link_text A label for the link to include . Only works in combination with $link_url .
* Default empty string .
2014-11-16 01:11:22 -05:00
* @ type bool $back_link Whether to include a link to go back . Default false .
2020-07-25 11:26:05 -04:00
* @ type string $text_direction The text direction . This is only useful internally , when WordPress is still
* loading and the site 's locale is not set up yet. Accepts ' rtl ' and ' ltr ' .
2016-05-02 00:00:28 -04:00
* Default is the value of is_rtl () .
2019-09-14 11:42:56 -04:00
* @ type string $charset Character set of the HTML output . Default 'utf-8' .
2019-01-21 11:02:50 -05:00
* @ type string $code Error code to use . Default is 'wp_die' , or the main error code if $message
* is a WP_Error .
2019-01-21 14:10:52 -05:00
* @ type bool $exit Whether to exit the process after completion . Default true .
2014-11-16 01:11:22 -05:00
* }
2008-08-09 00:51:51 -04:00
*/
2012-01-31 17:12:58 -05:00
function wp_die ( $message = '' , $title = '' , $args = array () ) {
2019-04-15 19:49:53 -04:00
global $wp_query ;
2014-11-16 01:11:22 -05:00
if ( is_int ( $args ) ) {
$args = array ( 'response' => $args );
} elseif ( is_int ( $title ) ) {
$args = array ( 'response' => $title );
$title = '' ;
}
2016-08-23 10:33:30 -04:00
if ( wp_doing_ajax () ) {
2014-04-13 20:20:14 -04:00
/**
2016-07-09 20:51:30 -04:00
* Filters the callback for killing WordPress execution for Ajax requests .
2014-04-13 20:20:14 -04:00
*
* @ since 3.4 . 0
*
Code Modernization: Rename parameters that use reserved keywords in `wp_die_*_handler` filters.
While using reserved PHP keywords as parameter name labels is allowed, in the context of function calls using named parameters in PHP 8.0+, this will easily lead to confusion. To avoid that, it is recommended not to use reserved keywords as function parameter names.
This commit renames the `$function` parameter to `$callback` in `wp_die_*_handler` filters, which aims to make it easier to use a non-reserved parameter name for anyone utilizing these filters.
Follow-up to [52946], [52996], [52997], [52998], [53003], [53014], [53029], [53039], [53116], [53117], [53137], [53174], [53184], [53185], [53192], [53193], [53198], [53203], [53207], [53215], [53216], [53220], [53230], [53232], [53236], [53239], [53240], [53242].
Props jrf, aristath, poena, justinahinon, SergeyBiryukov.
See #55327.
Built from https://develop.svn.wordpress.org/trunk@53243
git-svn-id: http://core.svn.wordpress.org/trunk@52832 1a063a9b-81f0-0310-95a4-ce76da25c4cd
2022-04-22 06:43:20 -04:00
* @ param callable $callback Callback function name .
2014-04-13 20:20:14 -04:00
*/
Code Modernization: Rename parameters that use reserved keywords in `wp_die_*_handler` filters.
While using reserved PHP keywords as parameter name labels is allowed, in the context of function calls using named parameters in PHP 8.0+, this will easily lead to confusion. To avoid that, it is recommended not to use reserved keywords as function parameter names.
This commit renames the `$function` parameter to `$callback` in `wp_die_*_handler` filters, which aims to make it easier to use a non-reserved parameter name for anyone utilizing these filters.
Follow-up to [52946], [52996], [52997], [52998], [53003], [53014], [53029], [53039], [53116], [53117], [53137], [53174], [53184], [53185], [53192], [53193], [53198], [53203], [53207], [53215], [53216], [53220], [53230], [53232], [53236], [53239], [53240], [53242].
Props jrf, aristath, poena, justinahinon, SergeyBiryukov.
See #55327.
Built from https://develop.svn.wordpress.org/trunk@53243
git-svn-id: http://core.svn.wordpress.org/trunk@52832 1a063a9b-81f0-0310-95a4-ce76da25c4cd
2022-04-22 06:43:20 -04:00
$callback = apply_filters ( 'wp_die_ajax_handler' , '_ajax_wp_die_handler' );
2019-01-16 10:22:56 -05:00
} elseif ( wp_is_json_request () ) {
/**
* Filters the callback for killing WordPress execution for JSON requests .
*
* @ since 5.1 . 0
*
Code Modernization: Rename parameters that use reserved keywords in `wp_die_*_handler` filters.
While using reserved PHP keywords as parameter name labels is allowed, in the context of function calls using named parameters in PHP 8.0+, this will easily lead to confusion. To avoid that, it is recommended not to use reserved keywords as function parameter names.
This commit renames the `$function` parameter to `$callback` in `wp_die_*_handler` filters, which aims to make it easier to use a non-reserved parameter name for anyone utilizing these filters.
Follow-up to [52946], [52996], [52997], [52998], [53003], [53014], [53029], [53039], [53116], [53117], [53137], [53174], [53184], [53185], [53192], [53193], [53198], [53203], [53207], [53215], [53216], [53220], [53230], [53232], [53236], [53239], [53240], [53242].
Props jrf, aristath, poena, justinahinon, SergeyBiryukov.
See #55327.
Built from https://develop.svn.wordpress.org/trunk@53243
git-svn-id: http://core.svn.wordpress.org/trunk@52832 1a063a9b-81f0-0310-95a4-ce76da25c4cd
2022-04-22 06:43:20 -04:00
* @ param callable $callback Callback function name .
2019-01-16 10:22:56 -05:00
*/
Code Modernization: Rename parameters that use reserved keywords in `wp_die_*_handler` filters.
While using reserved PHP keywords as parameter name labels is allowed, in the context of function calls using named parameters in PHP 8.0+, this will easily lead to confusion. To avoid that, it is recommended not to use reserved keywords as function parameter names.
This commit renames the `$function` parameter to `$callback` in `wp_die_*_handler` filters, which aims to make it easier to use a non-reserved parameter name for anyone utilizing these filters.
Follow-up to [52946], [52996], [52997], [52998], [53003], [53014], [53029], [53039], [53116], [53117], [53137], [53174], [53184], [53185], [53192], [53193], [53198], [53203], [53207], [53215], [53216], [53220], [53230], [53232], [53236], [53239], [53240], [53242].
Props jrf, aristath, poena, justinahinon, SergeyBiryukov.
See #55327.
Built from https://develop.svn.wordpress.org/trunk@53243
git-svn-id: http://core.svn.wordpress.org/trunk@52832 1a063a9b-81f0-0310-95a4-ce76da25c4cd
2022-04-22 06:43:20 -04:00
$callback = apply_filters ( 'wp_die_json_handler' , '_json_wp_die_handler' );
2021-09-08 13:16:57 -04:00
} elseif ( defined ( 'REST_REQUEST' ) && REST_REQUEST && wp_is_jsonp_request () ) {
2019-03-26 18:26:52 -04:00
/**
2021-09-08 13:16:57 -04:00
* Filters the callback for killing WordPress execution for JSONP REST requests .
2019-03-26 18:26:52 -04:00
*
* @ since 5.2 . 0
*
Code Modernization: Rename parameters that use reserved keywords in `wp_die_*_handler` filters.
While using reserved PHP keywords as parameter name labels is allowed, in the context of function calls using named parameters in PHP 8.0+, this will easily lead to confusion. To avoid that, it is recommended not to use reserved keywords as function parameter names.
This commit renames the `$function` parameter to `$callback` in `wp_die_*_handler` filters, which aims to make it easier to use a non-reserved parameter name for anyone utilizing these filters.
Follow-up to [52946], [52996], [52997], [52998], [53003], [53014], [53029], [53039], [53116], [53117], [53137], [53174], [53184], [53185], [53192], [53193], [53198], [53203], [53207], [53215], [53216], [53220], [53230], [53232], [53236], [53239], [53240], [53242].
Props jrf, aristath, poena, justinahinon, SergeyBiryukov.
See #55327.
Built from https://develop.svn.wordpress.org/trunk@53243
git-svn-id: http://core.svn.wordpress.org/trunk@52832 1a063a9b-81f0-0310-95a4-ce76da25c4cd
2022-04-22 06:43:20 -04:00
* @ param callable $callback Callback function name .
2019-03-26 18:26:52 -04:00
*/
Code Modernization: Rename parameters that use reserved keywords in `wp_die_*_handler` filters.
While using reserved PHP keywords as parameter name labels is allowed, in the context of function calls using named parameters in PHP 8.0+, this will easily lead to confusion. To avoid that, it is recommended not to use reserved keywords as function parameter names.
This commit renames the `$function` parameter to `$callback` in `wp_die_*_handler` filters, which aims to make it easier to use a non-reserved parameter name for anyone utilizing these filters.
Follow-up to [52946], [52996], [52997], [52998], [53003], [53014], [53029], [53039], [53116], [53117], [53137], [53174], [53184], [53185], [53192], [53193], [53198], [53203], [53207], [53215], [53216], [53220], [53230], [53232], [53236], [53239], [53240], [53242].
Props jrf, aristath, poena, justinahinon, SergeyBiryukov.
See #55327.
Built from https://develop.svn.wordpress.org/trunk@53243
git-svn-id: http://core.svn.wordpress.org/trunk@52832 1a063a9b-81f0-0310-95a4-ce76da25c4cd
2022-04-22 06:43:20 -04:00
$callback = apply_filters ( 'wp_die_jsonp_handler' , '_jsonp_wp_die_handler' );
2014-04-13 20:20:14 -04:00
} elseif ( defined ( 'XMLRPC_REQUEST' ) && XMLRPC_REQUEST ) {
/**
2016-07-09 20:51:30 -04:00
* Filters the callback for killing WordPress execution for XML - RPC requests .
2014-04-13 20:20:14 -04:00
*
* @ since 3.4 . 0
*
Code Modernization: Rename parameters that use reserved keywords in `wp_die_*_handler` filters.
While using reserved PHP keywords as parameter name labels is allowed, in the context of function calls using named parameters in PHP 8.0+, this will easily lead to confusion. To avoid that, it is recommended not to use reserved keywords as function parameter names.
This commit renames the `$function` parameter to `$callback` in `wp_die_*_handler` filters, which aims to make it easier to use a non-reserved parameter name for anyone utilizing these filters.
Follow-up to [52946], [52996], [52997], [52998], [53003], [53014], [53029], [53039], [53116], [53117], [53137], [53174], [53184], [53185], [53192], [53193], [53198], [53203], [53207], [53215], [53216], [53220], [53230], [53232], [53236], [53239], [53240], [53242].
Props jrf, aristath, poena, justinahinon, SergeyBiryukov.
See #55327.
Built from https://develop.svn.wordpress.org/trunk@53243
git-svn-id: http://core.svn.wordpress.org/trunk@52832 1a063a9b-81f0-0310-95a4-ce76da25c4cd
2022-04-22 06:43:20 -04:00
* @ param callable $callback Callback function name .
2014-04-13 20:20:14 -04:00
*/
Code Modernization: Rename parameters that use reserved keywords in `wp_die_*_handler` filters.
While using reserved PHP keywords as parameter name labels is allowed, in the context of function calls using named parameters in PHP 8.0+, this will easily lead to confusion. To avoid that, it is recommended not to use reserved keywords as function parameter names.
This commit renames the `$function` parameter to `$callback` in `wp_die_*_handler` filters, which aims to make it easier to use a non-reserved parameter name for anyone utilizing these filters.
Follow-up to [52946], [52996], [52997], [52998], [53003], [53014], [53029], [53039], [53116], [53117], [53137], [53174], [53184], [53185], [53192], [53193], [53198], [53203], [53207], [53215], [53216], [53220], [53230], [53232], [53236], [53239], [53240], [53242].
Props jrf, aristath, poena, justinahinon, SergeyBiryukov.
See #55327.
Built from https://develop.svn.wordpress.org/trunk@53243
git-svn-id: http://core.svn.wordpress.org/trunk@52832 1a063a9b-81f0-0310-95a4-ce76da25c4cd
2022-04-22 06:43:20 -04:00
$callback = apply_filters ( 'wp_die_xmlrpc_handler' , '_xmlrpc_wp_die_handler' );
2019-03-26 19:11:52 -04:00
} elseif ( wp_is_xml_request ()
2019-04-15 19:49:53 -04:00
|| isset ( $wp_query ) &&
( function_exists ( 'is_feed' ) && is_feed ()
|| function_exists ( 'is_comment_feed' ) && is_comment_feed ()
|| function_exists ( 'is_trackback' ) && is_trackback () ) ) {
2019-03-26 19:11:52 -04:00
/**
* Filters the callback for killing WordPress execution for XML requests .
*
* @ since 5.2 . 0
*
Code Modernization: Rename parameters that use reserved keywords in `wp_die_*_handler` filters.
While using reserved PHP keywords as parameter name labels is allowed, in the context of function calls using named parameters in PHP 8.0+, this will easily lead to confusion. To avoid that, it is recommended not to use reserved keywords as function parameter names.
This commit renames the `$function` parameter to `$callback` in `wp_die_*_handler` filters, which aims to make it easier to use a non-reserved parameter name for anyone utilizing these filters.
Follow-up to [52946], [52996], [52997], [52998], [53003], [53014], [53029], [53039], [53116], [53117], [53137], [53174], [53184], [53185], [53192], [53193], [53198], [53203], [53207], [53215], [53216], [53220], [53230], [53232], [53236], [53239], [53240], [53242].
Props jrf, aristath, poena, justinahinon, SergeyBiryukov.
See #55327.
Built from https://develop.svn.wordpress.org/trunk@53243
git-svn-id: http://core.svn.wordpress.org/trunk@52832 1a063a9b-81f0-0310-95a4-ce76da25c4cd
2022-04-22 06:43:20 -04:00
* @ param callable $callback Callback function name .
2019-03-26 19:11:52 -04:00
*/
Code Modernization: Rename parameters that use reserved keywords in `wp_die_*_handler` filters.
While using reserved PHP keywords as parameter name labels is allowed, in the context of function calls using named parameters in PHP 8.0+, this will easily lead to confusion. To avoid that, it is recommended not to use reserved keywords as function parameter names.
This commit renames the `$function` parameter to `$callback` in `wp_die_*_handler` filters, which aims to make it easier to use a non-reserved parameter name for anyone utilizing these filters.
Follow-up to [52946], [52996], [52997], [52998], [53003], [53014], [53029], [53039], [53116], [53117], [53137], [53174], [53184], [53185], [53192], [53193], [53198], [53203], [53207], [53215], [53216], [53220], [53230], [53232], [53236], [53239], [53240], [53242].
Props jrf, aristath, poena, justinahinon, SergeyBiryukov.
See #55327.
Built from https://develop.svn.wordpress.org/trunk@53243
git-svn-id: http://core.svn.wordpress.org/trunk@52832 1a063a9b-81f0-0310-95a4-ce76da25c4cd
2022-04-22 06:43:20 -04:00
$callback = apply_filters ( 'wp_die_xml_handler' , '_xml_wp_die_handler' );
2014-04-13 20:20:14 -04:00
} else {
/**
2019-03-26 19:11:52 -04:00
* Filters the callback for killing WordPress execution for all non - Ajax , non - JSON , non - XML requests .
2014-04-13 20:20:14 -04:00
*
* @ since 3.0 . 0
*
Code Modernization: Rename parameters that use reserved keywords in `wp_die_*_handler` filters.
While using reserved PHP keywords as parameter name labels is allowed, in the context of function calls using named parameters in PHP 8.0+, this will easily lead to confusion. To avoid that, it is recommended not to use reserved keywords as function parameter names.
This commit renames the `$function` parameter to `$callback` in `wp_die_*_handler` filters, which aims to make it easier to use a non-reserved parameter name for anyone utilizing these filters.
Follow-up to [52946], [52996], [52997], [52998], [53003], [53014], [53029], [53039], [53116], [53117], [53137], [53174], [53184], [53185], [53192], [53193], [53198], [53203], [53207], [53215], [53216], [53220], [53230], [53232], [53236], [53239], [53240], [53242].
Props jrf, aristath, poena, justinahinon, SergeyBiryukov.
See #55327.
Built from https://develop.svn.wordpress.org/trunk@53243
git-svn-id: http://core.svn.wordpress.org/trunk@52832 1a063a9b-81f0-0310-95a4-ce76da25c4cd
2022-04-22 06:43:20 -04:00
* @ param callable $callback Callback function name .
2014-04-13 20:20:14 -04:00
*/
Code Modernization: Rename parameters that use reserved keywords in `wp_die_*_handler` filters.
While using reserved PHP keywords as parameter name labels is allowed, in the context of function calls using named parameters in PHP 8.0+, this will easily lead to confusion. To avoid that, it is recommended not to use reserved keywords as function parameter names.
This commit renames the `$function` parameter to `$callback` in `wp_die_*_handler` filters, which aims to make it easier to use a non-reserved parameter name for anyone utilizing these filters.
Follow-up to [52946], [52996], [52997], [52998], [53003], [53014], [53029], [53039], [53116], [53117], [53137], [53174], [53184], [53185], [53192], [53193], [53198], [53203], [53207], [53215], [53216], [53220], [53230], [53232], [53236], [53239], [53240], [53242].
Props jrf, aristath, poena, justinahinon, SergeyBiryukov.
See #55327.
Built from https://develop.svn.wordpress.org/trunk@53243
git-svn-id: http://core.svn.wordpress.org/trunk@52832 1a063a9b-81f0-0310-95a4-ce76da25c4cd
2022-04-22 06:43:20 -04:00
$callback = apply_filters ( 'wp_die_handler' , '_default_wp_die_handler' );
2014-04-13 20:20:14 -04:00
}
2010-01-21 17:13:20 -05:00
Code Modernization: Rename parameters that use reserved keywords in `wp_die_*_handler` filters.
While using reserved PHP keywords as parameter name labels is allowed, in the context of function calls using named parameters in PHP 8.0+, this will easily lead to confusion. To avoid that, it is recommended not to use reserved keywords as function parameter names.
This commit renames the `$function` parameter to `$callback` in `wp_die_*_handler` filters, which aims to make it easier to use a non-reserved parameter name for anyone utilizing these filters.
Follow-up to [52946], [52996], [52997], [52998], [53003], [53014], [53029], [53039], [53116], [53117], [53137], [53174], [53184], [53185], [53192], [53193], [53198], [53203], [53207], [53215], [53216], [53220], [53230], [53232], [53236], [53239], [53240], [53242].
Props jrf, aristath, poena, justinahinon, SergeyBiryukov.
See #55327.
Built from https://develop.svn.wordpress.org/trunk@53243
git-svn-id: http://core.svn.wordpress.org/trunk@52832 1a063a9b-81f0-0310-95a4-ce76da25c4cd
2022-04-22 06:43:20 -04:00
call_user_func ( $callback , $message , $title , $args );
2010-01-21 17:13:20 -05:00
}
/**
2019-03-16 21:45:50 -04:00
* Kills WordPress execution and displays HTML page with an error message .
2010-01-21 17:13:20 -05:00
*
2019-03-16 21:45:50 -04:00
* This is the default handler for wp_die () . If you want a custom one ,
* you can override this using the { @ see 'wp_die_handler' } filter in wp_die () .
2010-01-21 17:13:20 -05:00
*
* @ since 3.0 . 0
2010-05-03 09:27:15 -04:00
* @ access private
2010-01-25 17:09:43 -05:00
*
2016-09-03 23:41:31 -04:00
* @ param string | WP_Error $message Error message or WP_Error object .
2023-02-21 11:39:19 -05:00
* @ param string $title Optional . Error title . Default empty string .
2016-09-03 23:41:31 -04:00
* @ param string | array $args Optional . Arguments to control behavior . Default empty array .
2010-01-21 17:13:20 -05:00
*/
function _default_wp_die_handler ( $message , $title = '' , $args = array () ) {
2019-07-24 20:48:58 -04:00
list ( $message , $title , $parsed_args ) = _wp_die_process_input ( $message , $title , $args );
2009-05-24 19:47:49 -04:00
2019-01-21 11:02:50 -05:00
if ( is_string ( $message ) ) {
2019-07-24 20:48:58 -04:00
if ( ! empty ( $parsed_args [ 'additional_errors' ] ) ) {
2019-01-21 11:02:50 -05:00
$message = array_merge (
array ( $message ),
2019-07-24 20:48:58 -04:00
wp_list_pluck ( $parsed_args [ 'additional_errors' ], 'message' )
2019-01-21 11:02:50 -05:00
);
2020-10-18 13:27:06 -04:00
$message = " <ul> \n \t \t <li> " . implode ( " </li> \n \t \t <li> " , $message ) . " </li> \n \t </ul> " ;
2014-05-30 13:58:15 -04:00
}
2019-08-29 03:54:01 -04:00
$message = sprintf (
'<div class="wp-die-message">%s</div>' ,
$message
);
2007-02-19 20:24:31 -05:00
}
2009-05-24 19:47:49 -04:00
2019-01-21 11:02:50 -05:00
$have_gettext = function_exists ( '__' );
2019-07-24 20:48:58 -04:00
if ( ! empty ( $parsed_args [ 'link_url' ] ) && ! empty ( $parsed_args [ 'link_text' ] ) ) {
$link_url = $parsed_args [ 'link_url' ];
2019-01-16 10:21:50 -05:00
if ( function_exists ( 'esc_url' ) ) {
$link_url = esc_url ( $link_url );
}
2019-07-24 20:48:58 -04:00
$link_text = $parsed_args [ 'link_text' ];
2019-01-16 10:21:50 -05:00
$message .= " \n <p><a href=' { $link_url } '> { $link_text } </a></p> " ;
}
2019-07-24 20:48:58 -04:00
if ( isset ( $parsed_args [ 'back_link' ] ) && $parsed_args [ 'back_link' ] ) {
2017-11-30 18:11:00 -05:00
$back_text = $have_gettext ? __ ( '« Back' ) : '« Back' ;
$message .= " \n <p><a href='javascript:history.back()'> $back_text </a></p> " ;
2009-05-15 13:49:35 -04:00
}
2009-05-24 19:47:49 -04:00
2012-01-31 17:12:58 -05:00
if ( ! did_action ( 'admin_head' ) ) :
2017-11-30 18:11:00 -05:00
if ( ! headers_sent () ) {
2019-09-14 11:42:56 -04:00
header ( " Content-Type: text/html; charset= { $parsed_args [ 'charset' ] } " );
2019-07-24 20:48:58 -04:00
status_header ( $parsed_args [ 'response' ] );
2011-08-11 15:06:59 -04:00
nocache_headers ();
}
2011-10-24 15:13:23 -04:00
2019-07-24 20:48:58 -04:00
$text_direction = $parsed_args [ 'text_direction' ];
2020-07-25 11:26:05 -04:00
$dir_attr = " dir=' $text_direction ' " ;
2023-07-10 18:38:25 -04:00
/*
* If `text_direction` was not explicitly passed ,
* use get_language_attributes () if available .
*/
2020-07-25 11:26:05 -04:00
if ( empty ( $args [ 'text_direction' ] )
&& function_exists ( 'language_attributes' ) && function_exists ( 'is_rtl' )
) {
2017-11-30 18:11:00 -05:00
$dir_attr = get_language_attributes ();
}
2018-08-16 21:51:36 -04:00
?>
2011-07-21 20:25:41 -04:00
<! DOCTYPE html >
2020-06-22 17:26:16 -04:00
< html < ? php echo $dir_attr ; ?> >
2006-07-10 01:29:10 -04:00
< head >
2019-09-14 11:42:56 -04:00
< meta http - equiv = " Content-Type " content = " text/html; charset=<?php echo $parsed_args['charset'] ; ?> " />
2015-05-13 00:08:25 -04:00
< meta name = " viewport " content = " width=device-width " >
2018-08-16 21:51:36 -04:00
< ? php
Robots: Introduce Robots API.
This changeset introduces a filter-based Robots API, providing central control over the `robots` meta tag.
* Introduces `wp_robots()` function which should be called anywhere a `robots` meta tag should be included.
* Introduces `wp_robots` filter which allows adding or modifying directives for the `robots` meta tag. The `wp_robots()` function is entirely filter-based, i.e. if no filter is added to `wp_robots`, no directives will be present, and therefore the entire `robots` meta tag will be omitted.
* Introduces the following `wp_robots` filter functions which replace similar existing functions that were manually rendering a `robots` meta tag:
* `wp_robots_noindex()` replaces `noindex()`, which has been deprecated.
* `wp_robots_no_robots()` replaces `wp_no_robots()`, which has been deprecated.
* `wp_robots_sensitive_page()` replaces `wp_sensitive_page_meta()`, which has been deprecated. Its rendering of the `referrer` meta tag has been moved to another new function `wp_strict_cross_origin_referrer()`.
Migration to the new functions is straightforward. For example, a call to `add_action( 'wp_head', 'wp_no_robots' )` should be replaced with `add_filter( 'wp_robots', 'wp_robots_no_robots' )`.
Plugins and themes that render their own `robots` meta tags are encouraged to switch to rely on the `wp_robots` filter in order to use the central management layer now provided by WordPress core.
Props adamsilverstein, flixos90, timothyblynjacobs, westonruter.
See #51511.
Built from https://develop.svn.wordpress.org/trunk@49992
git-svn-id: http://core.svn.wordpress.org/trunk@49693 1a063a9b-81f0-0310-95a4-ce76da25c4cd
2021-01-20 20:37:00 -05:00
if ( function_exists ( 'wp_robots' ) && function_exists ( 'wp_robots_no_robots' ) && function_exists ( 'add_filter' ) ) {
add_filter ( 'wp_robots' , 'wp_robots_no_robots' );
wp_robots ();
2018-08-16 21:51:36 -04:00
}
?>
2017-11-30 18:11:00 -05:00
< title >< ? php echo $title ; ?> </title>
2011-08-11 15:06:59 -04:00
< style type = " text/css " >
html {
2014-03-29 19:06:14 -04:00
background : #f1f1f1;
2011-08-11 15:06:59 -04:00
}
body {
background : #fff;
2020-12-26 14:54:07 -05:00
border : 1 px solid #ccd0d4;
2014-03-29 19:06:14 -04:00
color : #444;
2016-07-26 12:39:30 -04:00
font - family : - apple - system , BlinkMacSystemFont , " Segoe UI " , Roboto , Oxygen - Sans , Ubuntu , Cantarell , " Helvetica Neue " , sans - serif ;
2011-08-11 15:06:59 -04:00
margin : 2 em auto ;
padding : 1 em 2 em ;
2011-11-15 10:47:07 -05:00
max - width : 700 px ;
2020-12-26 14:54:07 -05:00
- webkit - box - shadow : 0 1 px 1 px rgba ( 0 , 0 , 0 , . 04 );
box - shadow : 0 1 px 1 px rgba ( 0 , 0 , 0 , . 04 );
2011-08-11 15:06:59 -04:00
}
2012-03-18 07:51:25 -04:00
h1 {
border - bottom : 1 px solid #dadada;
clear : both ;
color : #666;
Drop Open Sans in the admin in favor of system fonts.
Rejoice, for your admins will feel more native to your surrounding computing environment and likely load faster, especially when offline, as they no longer have to talk to The Google Overlord.
At the time of introduction in 3.8, there were not good system fonts common to all platforms at the time. In the years since, Windows, Android, OS X, iOS, Firefox OS, and various flavors of Linux have all gotten their own (good) system UI fonts.
There will definitely be visual bugs, mainly around alignment and spacing; these should be documented and reported on the ticket and fixed more atomically so that our current and future selves have a better understanding of what happened and why.
The style remains registered, as it is almost certainly in use by themes and plugins.
props mattmiklic.
see #36753.
Built from https://develop.svn.wordpress.org/trunk@37361
git-svn-id: http://core.svn.wordpress.org/trunk@37327 1a063a9b-81f0-0310-95a4-ce76da25c4cd
2016-05-04 18:07:37 -04:00
font - size : 24 px ;
2012-03-18 07:51:25 -04:00
margin : 30 px 0 0 0 ;
padding : 0 ;
padding - bottom : 7 px ;
}
2011-08-11 15:06:59 -04:00
#error-page {
margin - top : 50 px ;
}
2019-08-29 03:54:01 -04:00
#error-page p,
#error-page .wp-die-message {
2011-11-15 10:47:07 -05:00
font - size : 14 px ;
line - height : 1.5 ;
2011-08-11 15:06:59 -04:00
margin : 25 px 0 20 px ;
}
#error-page code {
font - family : Consolas , Monaco , monospace ;
}
2011-11-15 10:47:07 -05:00
ul li {
margin - bottom : 10 px ;
font - size : 14 px ;
}
a {
2015-10-21 11:23:26 -04:00
color : #0073aa;
2011-11-15 10:47:07 -05:00
}
2015-11-03 12:59:24 -05:00
a : hover ,
a : active {
2020-07-07 06:11:05 -04:00
color : #006799;
2015-10-21 11:23:26 -04:00
}
a : focus {
color : #124964;
2017-11-30 18:11:00 -05:00
- webkit - box - shadow :
0 0 0 1 px #5b9dd9,
2019-03-04 17:02:52 -05:00
0 0 2 px 1 px rgba ( 30 , 140 , 190 , 0.8 );
2017-11-30 18:11:00 -05:00
box - shadow :
0 0 0 1 px #5b9dd9,
2019-03-04 17:02:52 -05:00
0 0 2 px 1 px rgba ( 30 , 140 , 190 , 0.8 );
2015-10-21 11:23:26 -04:00
outline : none ;
2011-11-15 10:47:07 -05:00
}
2011-11-23 12:29:49 -05:00
. button {
2020-12-26 14:54:07 -05:00
background : #f3f5f6;
border : 1 px solid #016087;
color : #016087;
2012-10-26 15:40:39 -04:00
display : inline - block ;
2011-11-23 12:29:49 -05:00
text - decoration : none ;
2013-11-20 19:25:10 -05:00
font - size : 13 px ;
2019-05-30 08:39:52 -04:00
line - height : 2 ;
2013-11-20 19:25:10 -05:00
height : 28 px ;
2012-10-26 15:40:39 -04:00
margin : 0 ;
padding : 0 10 px 1 px ;
2011-11-23 12:29:49 -05:00
cursor : pointer ;
2012-10-26 15:40:39 -04:00
- webkit - border - radius : 3 px ;
2013-11-20 19:25:10 -05:00
- webkit - appearance : none ;
2012-10-26 15:40:39 -04:00
border - radius : 3 px ;
white - space : nowrap ;
- webkit - box - sizing : border - box ;
- moz - box - sizing : border - box ;
box - sizing : border - box ;
2013-12-11 14:49:11 -05:00
2019-07-05 01:21:56 -04:00
vertical - align : top ;
2012-10-26 15:40:39 -04:00
}
2012-11-17 10:11:29 -05:00
2012-10-26 15:40:39 -04:00
. button . button - large {
2020-12-26 14:54:07 -05:00
line - height : 2.30769231 ;
min - height : 32 px ;
padding : 0 12 px ;
2011-11-23 12:29:49 -05:00
}
2012-10-26 15:40:39 -04:00
. button : hover ,
. button : focus {
2020-12-26 14:54:07 -05:00
background : #f1f1f1;
2012-10-26 15:40:39 -04:00
}
2012-11-17 10:11:29 -05:00
2019-03-04 17:02:52 -05:00
. button : focus {
2020-12-26 14:54:07 -05:00
background : #f3f5f6;
border - color : #007cba;
- webkit - box - shadow : 0 0 0 1 px #007cba;
box - shadow : 0 0 0 1 px #007cba;
color : #016087;
outline : 2 px solid transparent ;
outline - offset : 0 ;
2011-11-23 12:29:49 -05:00
}
. button : active {
2020-12-26 14:54:07 -05:00
background : #f3f5f6;
border - color : #7e8993;
- webkit - box - shadow : none ;
box - shadow : none ;
2011-11-23 12:29:49 -05:00
}
2011-12-30 17:25:53 -05:00
2015-10-02 21:32:24 -04:00
< ? php
2020-05-16 14:42:12 -04:00
if ( 'rtl' === $text_direction ) {
2015-10-02 21:32:24 -04:00
echo 'body { font-family: Tahoma, Arial; }' ;
}
?>
2011-08-11 15:06:59 -04:00
</ style >
2006-07-10 01:29:10 -04:00
</ head >
2008-02-23 23:33:51 -05:00
< body id = " error-page " >
2012-01-31 17:12:58 -05:00
< ? php endif ; // ! did_action( 'admin_head' ) ?>
2007-02-19 20:24:31 -05:00
< ? php echo $message ; ?>
2006-07-10 01:29:10 -04:00
</ body >
</ html >
2018-08-16 21:51:36 -04:00
< ? php
2019-07-24 20:48:58 -04:00
if ( $parsed_args [ 'exit' ] ) {
2019-01-21 14:10:52 -05:00
die ();
}
2006-07-05 15:13:26 -04:00
}
2019-03-26 19:11:52 -04:00
/**
* Kills WordPress execution and displays Ajax response with an error message .
*
* This is the handler for wp_die () when processing Ajax requests .
*
* @ since 3.4 . 0
* @ access private
*
* @ param string $message Error message .
2023-02-21 11:39:19 -05:00
* @ param string $title Optional . Error title ( unused ) . Default empty string .
2019-03-26 19:11:52 -04:00
* @ param string | array $args Optional . Arguments to control behavior . Default empty array .
*/
function _ajax_wp_die_handler ( $message , $title = '' , $args = array () ) {
2020-06-25 08:43:07 -04:00
// Set default 'response' to 200 for Ajax requests.
2019-03-26 19:11:52 -04:00
$args = wp_parse_args (
$args ,
array ( 'response' => 200 )
);
2019-07-24 20:48:58 -04:00
list ( $message , $title , $parsed_args ) = _wp_die_process_input ( $message , $title , $args );
2019-03-26 19:11:52 -04:00
if ( ! headers_sent () ) {
// This is intentional. For backward-compatibility, support passing null here.
if ( null !== $args [ 'response' ] ) {
2019-07-24 20:48:58 -04:00
status_header ( $parsed_args [ 'response' ] );
2019-03-26 19:11:52 -04:00
}
nocache_headers ();
}
if ( is_scalar ( $message ) ) {
$message = ( string ) $message ;
} else {
$message = '0' ;
}
2019-07-24 20:48:58 -04:00
if ( $parsed_args [ 'exit' ] ) {
2019-03-26 19:11:52 -04:00
die ( $message );
}
echo $message ;
}
2019-01-16 10:22:56 -05:00
/**
2019-03-16 21:45:50 -04:00
* Kills WordPress execution and displays JSON response with an error message .
2019-01-16 10:22:56 -05:00
*
2019-03-16 21:45:50 -04:00
* This is the handler for wp_die () when processing JSON requests .
2019-01-16 10:22:56 -05:00
*
* @ since 5.1 . 0
* @ access private
*
* @ param string $message Error message .
2023-02-21 11:39:19 -05:00
* @ param string $title Optional . Error title . Default empty string .
2019-01-16 10:22:56 -05:00
* @ param string | array $args Optional . Arguments to control behavior . Default empty array .
*/
function _json_wp_die_handler ( $message , $title = '' , $args = array () ) {
2019-07-24 20:48:58 -04:00
list ( $message , $title , $parsed_args ) = _wp_die_process_input ( $message , $title , $args );
2019-01-16 10:22:56 -05:00
$data = array (
2019-07-24 20:48:58 -04:00
'code' => $parsed_args [ 'code' ],
2019-01-21 11:02:50 -05:00
'message' => $message ,
'data' => array (
2019-07-24 20:48:58 -04:00
'status' => $parsed_args [ 'response' ],
2019-01-21 11:02:50 -05:00
),
2019-07-24 20:48:58 -04:00
'additional_errors' => $parsed_args [ 'additional_errors' ],
2019-01-16 10:22:56 -05:00
);
if ( ! headers_sent () ) {
2019-09-14 11:42:56 -04:00
header ( " Content-Type: application/json; charset= { $parsed_args [ 'charset' ] } " );
2019-07-24 20:48:58 -04:00
if ( null !== $parsed_args [ 'response' ] ) {
status_header ( $parsed_args [ 'response' ] );
2019-01-16 10:22:56 -05:00
}
2019-03-11 07:47:50 -04:00
nocache_headers ();
2019-01-16 10:22:56 -05:00
}
echo wp_json_encode ( $data );
2019-07-24 20:48:58 -04:00
if ( $parsed_args [ 'exit' ] ) {
2019-01-21 14:10:52 -05:00
die ();
}
2019-01-16 10:22:56 -05:00
}
2019-03-26 18:26:52 -04:00
/**
2019-03-26 19:18:53 -04:00
* Kills WordPress execution and displays JSONP response with an error message .
2019-03-26 18:26:52 -04:00
*
2019-03-26 19:18:53 -04:00
* This is the handler for wp_die () when processing JSONP requests .
2019-03-26 18:26:52 -04:00
*
* @ since 5.2 . 0
* @ access private
*
* @ param string $message Error message .
2023-02-21 11:39:19 -05:00
* @ param string $title Optional . Error title . Default empty string .
2019-03-26 18:26:52 -04:00
* @ param string | array $args Optional . Arguments to control behavior . Default empty array .
*/
function _jsonp_wp_die_handler ( $message , $title = '' , $args = array () ) {
2019-07-24 20:48:58 -04:00
list ( $message , $title , $parsed_args ) = _wp_die_process_input ( $message , $title , $args );
2019-03-26 18:26:52 -04:00
$data = array (
2019-07-24 20:48:58 -04:00
'code' => $parsed_args [ 'code' ],
2019-03-26 18:26:52 -04:00
'message' => $message ,
'data' => array (
2019-07-24 20:48:58 -04:00
'status' => $parsed_args [ 'response' ],
2019-03-26 18:26:52 -04:00
),
2019-07-24 20:48:58 -04:00
'additional_errors' => $parsed_args [ 'additional_errors' ],
2019-03-26 18:26:52 -04:00
);
if ( ! headers_sent () ) {
2019-09-14 11:42:56 -04:00
header ( " Content-Type: application/javascript; charset= { $parsed_args [ 'charset' ] } " );
2019-03-26 18:26:52 -04:00
header ( 'X-Content-Type-Options: nosniff' );
header ( 'X-Robots-Tag: noindex' );
2019-07-24 20:48:58 -04:00
if ( null !== $parsed_args [ 'response' ] ) {
status_header ( $parsed_args [ 'response' ] );
2019-03-26 18:26:52 -04:00
}
nocache_headers ();
}
$result = wp_json_encode ( $data );
$jsonp_callback = $_GET [ '_jsonp' ];
echo '/**/' . $jsonp_callback . '(' . $result . ')' ;
2019-07-24 20:48:58 -04:00
if ( $parsed_args [ 'exit' ] ) {
2019-03-26 18:26:52 -04:00
die ();
}
}
2011-04-17 04:35:51 -04:00
/**
2019-03-16 21:45:50 -04:00
* Kills WordPress execution and displays XML response with an error message .
2011-04-17 04:35:51 -04:00
*
2019-03-16 21:45:50 -04:00
* This is the handler for wp_die () when processing XMLRPC requests .
2011-04-17 04:35:51 -04:00
*
* @ since 3.2 . 0
* @ access private
*
2015-05-25 12:11:25 -04:00
* @ global wp_xmlrpc_server $wp_xmlrpc_server
*
2014-06-30 21:44:15 -04:00
* @ param string $message Error message .
2023-02-21 11:39:19 -05:00
* @ param string $title Optional . Error title . Default empty string .
2014-06-30 21:44:15 -04:00
* @ param string | array $args Optional . Arguments to control behavior . Default empty array .
2011-04-17 04:35:51 -04:00
*/
2011-05-14 15:45:07 -04:00
function _xmlrpc_wp_die_handler ( $message , $title = '' , $args = array () ) {
2011-04-17 04:35:51 -04:00
global $wp_xmlrpc_server ;
2019-07-24 20:48:58 -04:00
list ( $message , $title , $parsed_args ) = _wp_die_process_input ( $message , $title , $args );
2011-04-17 04:35:51 -04:00
2019-03-11 07:47:50 -04:00
if ( ! headers_sent () ) {
nocache_headers ();
}
2011-05-14 15:45:07 -04:00
if ( $wp_xmlrpc_server ) {
2019-07-24 20:48:58 -04:00
$error = new IXR_Error ( $parsed_args [ 'response' ], $message );
2011-05-14 15:45:07 -04:00
$wp_xmlrpc_server -> output ( $error -> getXml () );
2011-04-17 04:35:51 -04:00
}
2019-07-24 20:48:58 -04:00
if ( $parsed_args [ 'exit' ] ) {
2019-01-21 14:10:52 -05:00
die ();
}
2011-04-17 04:35:51 -04:00
}
/**
2019-03-26 19:18:53 -04:00
* Kills WordPress execution and displays XML response with an error message .
2011-05-14 15:45:07 -04:00
*
2019-03-26 19:18:53 -04:00
* This is the handler for wp_die () when processing XML requests .
2012-01-31 17:12:58 -05:00
*
2019-03-26 19:11:52 -04:00
* @ since 5.2 . 0
2011-04-17 04:35:51 -04:00
* @ access private
2012-01-31 17:12:58 -05:00
*
2016-08-31 12:31:29 -04:00
* @ param string $message Error message .
2023-02-21 11:39:19 -05:00
* @ param string $title Optional . Error title . Default empty string .
2016-08-31 12:31:29 -04:00
* @ param string | array $args Optional . Arguments to control behavior . Default empty array .
*/
2019-03-26 19:11:52 -04:00
function _xml_wp_die_handler ( $message , $title = '' , $args = array () ) {
2019-07-24 20:48:58 -04:00
list ( $message , $title , $parsed_args ) = _wp_die_process_input ( $message , $title , $args );
2016-08-31 12:31:29 -04:00
2019-03-26 19:11:52 -04:00
$message = htmlspecialchars ( $message );
$title = htmlspecialchars ( $title );
$xml = <<< EOD
< error >
2019-07-24 20:48:58 -04:00
< code > { $parsed_args [ 'code' ]} </ code >
2019-03-26 19:11:52 -04:00
< title ><! [ CDATA [{ $title }]] ></ title >
< message ><! [ CDATA [{ $message }]] ></ message >
< data >
2019-07-24 20:48:58 -04:00
< status > { $parsed_args [ 'response' ]} </ status >
2019-04-12 19:56:52 -04:00
</ data >
2019-03-26 19:11:52 -04:00
</ error >
EOD ;
2019-03-11 07:47:50 -04:00
if ( ! headers_sent () ) {
2019-09-14 11:42:56 -04:00
header ( " Content-Type: text/xml; charset= { $parsed_args [ 'charset' ] } " );
2019-07-24 20:48:58 -04:00
if ( null !== $parsed_args [ 'response' ] ) {
status_header ( $parsed_args [ 'response' ] );
2019-03-11 07:47:50 -04:00
}
nocache_headers ();
2016-08-28 13:31:30 -04:00
}
2016-10-26 10:32:28 -04:00
2019-03-26 19:11:52 -04:00
echo $xml ;
2019-07-24 20:48:58 -04:00
if ( $parsed_args [ 'exit' ] ) {
2019-03-26 19:11:52 -04:00
die ();
2019-01-21 14:10:52 -05:00
}
2011-04-17 04:35:51 -04:00
}
2012-03-01 16:35:15 -05:00
/**
2019-03-16 21:45:50 -04:00
* Kills WordPress execution and displays an error message .
2012-03-01 16:35:15 -05:00
*
2019-03-16 21:45:50 -04:00
* This is the handler for wp_die () when processing APP requests .
2012-03-01 16:35:15 -05:00
*
* @ since 3.4 . 0
2019-01-21 14:10:52 -05:00
* @ since 5.1 . 0 Added the $title and $args parameters .
2012-03-01 16:35:15 -05:00
* @ access private
*
2023-02-21 11:39:19 -05:00
* @ param string $message Optional . Response to print . Default empty string .
* @ param string $title Optional . Error title ( unused ) . Default empty string .
2019-01-21 14:10:52 -05:00
* @ param string | array $args Optional . Arguments to control behavior . Default empty array .
2012-03-01 16:35:15 -05:00
*/
2019-01-21 14:10:52 -05:00
function _scalar_wp_die_handler ( $message = '' , $title = '' , $args = array () ) {
2019-07-24 20:48:58 -04:00
list ( $message , $title , $parsed_args ) = _wp_die_process_input ( $message , $title , $args );
2019-01-21 14:10:52 -05:00
2019-07-24 20:48:58 -04:00
if ( $parsed_args [ 'exit' ] ) {
2019-01-21 14:10:52 -05:00
if ( is_scalar ( $message ) ) {
die ( ( string ) $message );
}
die ();
}
2017-11-30 18:11:00 -05:00
if ( is_scalar ( $message ) ) {
2019-01-21 14:10:52 -05:00
echo ( string ) $message ;
2017-11-30 18:11:00 -05:00
}
2012-03-01 16:35:15 -05:00
}
2019-01-21 11:02:50 -05:00
/**
2019-03-16 21:45:50 -04:00
* Processes arguments passed to wp_die () consistently for its handlers .
2019-01-21 11:02:50 -05:00
*
* @ since 5.1 . 0
* @ access private
*
2019-09-17 17:03:54 -04:00
* @ param string | WP_Error $message Error message or WP_Error object .
2023-02-21 11:39:19 -05:00
* @ param string $title Optional . Error title . Default empty string .
2019-09-17 17:03:54 -04:00
* @ param string | array $args Optional . Arguments to control behavior . Default empty array .
* @ return array {
* Processed arguments .
*
* @ type string $ 0 Error message .
* @ type string $ 1 Error title .
* @ type array $ 2 Arguments to control behavior .
* }
2019-01-21 11:02:50 -05:00
*/
function _wp_die_process_input ( $message , $title = '' , $args = array () ) {
$defaults = array (
'response' => 0 ,
'code' => '' ,
2019-01-21 14:10:52 -05:00
'exit' => true ,
2019-01-21 11:02:50 -05:00
'back_link' => false ,
'link_url' => '' ,
'link_text' => '' ,
'text_direction' => '' ,
2019-09-14 11:42:56 -04:00
'charset' => 'utf-8' ,
2019-01-21 11:02:50 -05:00
'additional_errors' => array (),
);
$args = wp_parse_args ( $args , $defaults );
if ( function_exists ( 'is_wp_error' ) && is_wp_error ( $message ) ) {
if ( ! empty ( $message -> errors ) ) {
$errors = array ();
foreach ( ( array ) $message -> errors as $error_code => $error_messages ) {
foreach ( ( array ) $error_messages as $error_message ) {
$errors [] = array (
'code' => $error_code ,
'message' => $error_message ,
2019-01-22 03:52:50 -05:00
'data' => $message -> get_error_data ( $error_code ),
2019-01-21 11:02:50 -05:00
);
}
}
$message = $errors [ 0 ][ 'message' ];
if ( empty ( $args [ 'code' ] ) ) {
$args [ 'code' ] = $errors [ 0 ][ 'code' ];
}
if ( empty ( $args [ 'response' ] ) && is_array ( $errors [ 0 ][ 'data' ] ) && ! empty ( $errors [ 0 ][ 'data' ][ 'status' ] ) ) {
$args [ 'response' ] = $errors [ 0 ][ 'data' ][ 'status' ];
}
if ( empty ( $title ) && is_array ( $errors [ 0 ][ 'data' ] ) && ! empty ( $errors [ 0 ][ 'data' ][ 'title' ] ) ) {
$title = $errors [ 0 ][ 'data' ][ 'title' ];
}
unset ( $errors [ 0 ] );
$args [ 'additional_errors' ] = array_values ( $errors );
} else {
$message = '' ;
}
}
$have_gettext = function_exists ( '__' );
// The $title and these specific $args must always have a non-empty value.
if ( empty ( $args [ 'code' ] ) ) {
$args [ 'code' ] = 'wp_die' ;
}
if ( empty ( $args [ 'response' ] ) ) {
$args [ 'response' ] = 500 ;
}
if ( empty ( $title ) ) {
$title = $have_gettext ? __ ( 'WordPress › Error' ) : 'WordPress › Error' ;
}
if ( empty ( $args [ 'text_direction' ] ) || ! in_array ( $args [ 'text_direction' ], array ( 'ltr' , 'rtl' ), true ) ) {
$args [ 'text_direction' ] = 'ltr' ;
if ( function_exists ( 'is_rtl' ) && is_rtl () ) {
$args [ 'text_direction' ] = 'rtl' ;
}
}
2019-09-14 11:42:56 -04:00
if ( ! empty ( $args [ 'charset' ] ) ) {
$args [ 'charset' ] = _canonical_charset ( $args [ 'charset' ] );
}
2019-01-21 11:02:50 -05:00
return array ( $message , $title , $args );
}
2014-10-28 14:35:19 -04:00
/**
2022-08-12 05:53:11 -04:00
* Encodes a variable into JSON , with some sanity checks .
2014-10-28 14:35:19 -04:00
*
* @ since 4.1 . 0
2019-09-20 16:08:57 -04:00
* @ since 5.3 . 0 No longer handles support for PHP < 5.6 .
2014-10-28 14:35:19 -04:00
*
2014-10-28 17:29:23 -04:00
* @ param mixed $data Variable ( usually an array or object ) to encode as JSON .
2014-11-28 06:36:23 -05:00
* @ param int $options Optional . Options to be passed to json_encode () . Default 0.
* @ param int $depth Optional . Maximum depth to walk through $data . Must be
* greater than 0. Default 512.
2015-05-25 12:11:25 -04:00
* @ return string | false The JSON encoded string , or false if it cannot be encoded .
2014-10-28 14:35:19 -04:00
*/
function wp_json_encode ( $data , $options = 0 , $depth = 512 ) {
2019-09-20 16:08:57 -04:00
$json = json_encode ( $data , $options , $depth );
2014-10-28 14:35:19 -04:00
2014-10-28 17:29:23 -04:00
// If json_encode() was successful, no need to do more sanity checking.
2019-09-20 16:08:57 -04:00
if ( false !== $json ) {
2014-10-28 14:35:19 -04:00
return $json ;
}
try {
2019-09-20 16:08:57 -04:00
$data = _wp_json_sanity_check ( $data , $depth );
2014-10-28 14:35:19 -04:00
} catch ( Exception $e ) {
return false ;
}
2019-09-20 16:08:57 -04:00
return json_encode ( $data , $options , $depth );
2014-10-28 14:35:19 -04:00
}
/**
2022-08-12 05:53:11 -04:00
* Performs sanity checks on data that shall be encoded to JSON .
2014-10-28 17:29:23 -04:00
*
2015-01-12 19:51:21 -05:00
* @ ignore
2014-10-28 17:29:23 -04:00
* @ since 4.1 . 0
* @ access private
2015-01-12 19:51:21 -05:00
*
* @ see wp_json_encode ()
2014-10-28 17:29:23 -04:00
*
2020-03-04 06:34:08 -05:00
* @ throws Exception If depth limit is reached .
*
2014-10-28 17:29:23 -04:00
* @ param mixed $data Variable ( usually an array or object ) to encode as JSON .
* @ param int $depth Maximum depth to walk through $data . Must be greater than 0.
* @ return mixed The sanitized data that shall be encoded to JSON .
2014-10-28 14:35:19 -04:00
*/
function _wp_json_sanity_check ( $data , $depth ) {
if ( $depth < 0 ) {
throw new Exception ( 'Reached depth limit' );
}
if ( is_array ( $data ) ) {
$output = array ();
foreach ( $data as $id => $el ) {
// Don't forget to sanitize the ID!
if ( is_string ( $id ) ) {
$clean_id = _wp_json_convert_string ( $id );
} else {
$clean_id = $id ;
}
2014-10-28 17:29:23 -04:00
// Check the element type, so that we're only recursing if we really have to.
2014-10-28 14:35:19 -04:00
if ( is_array ( $el ) || is_object ( $el ) ) {
$output [ $clean_id ] = _wp_json_sanity_check ( $el , $depth - 1 );
2014-10-28 17:29:23 -04:00
} elseif ( is_string ( $el ) ) {
2014-10-28 14:35:19 -04:00
$output [ $clean_id ] = _wp_json_convert_string ( $el );
} else {
$output [ $clean_id ] = $el ;
}
}
2014-10-28 17:29:23 -04:00
} elseif ( is_object ( $data ) ) {
2022-11-29 10:51:14 -05:00
$output = new stdClass ();
2014-10-28 14:35:19 -04:00
foreach ( $data as $id => $el ) {
if ( is_string ( $id ) ) {
$clean_id = _wp_json_convert_string ( $id );
} else {
$clean_id = $id ;
}
if ( is_array ( $el ) || is_object ( $el ) ) {
$output -> $clean_id = _wp_json_sanity_check ( $el , $depth - 1 );
2014-10-28 17:29:23 -04:00
} elseif ( is_string ( $el ) ) {
2014-10-28 14:35:19 -04:00
$output -> $clean_id = _wp_json_convert_string ( $el );
} else {
$output -> $clean_id = $el ;
}
}
2014-10-28 17:29:23 -04:00
} elseif ( is_string ( $data ) ) {
2014-10-28 14:35:19 -04:00
return _wp_json_convert_string ( $data );
} else {
return $data ;
}
return $output ;
}
/**
2022-08-12 05:53:11 -04:00
* Converts a string to UTF - 8 , so that it can be safely encoded to JSON .
2014-10-28 17:29:23 -04:00
*
2015-01-12 19:51:21 -05:00
* @ ignore
2014-10-28 17:29:23 -04:00
* @ since 4.1 . 0
* @ access private
2015-01-12 19:51:21 -05:00
*
* @ see _wp_json_sanity_check ()
2014-10-28 17:29:23 -04:00
*
Code Modernization: Rename parameters that use reserved keywords in `wp-includes/functions.php`.
While using reserved PHP keywords as parameter name labels is allowed, in the context of function calls using named parameters in PHP 8.0+, this will easily lead to confusion. To avoid that, it is recommended not to use reserved keywords as function parameter names.
This commit:
* Renames the `$echo` parameter to `$display` in:
* `wp_nonce_field()`
* `wp_referer_field()`
* `wp_original_referer_field()`
* Renames the `$string` parameter to `$input_string` in
* `_wp_json_convert_string()`
* `_wp_to_kebab_case()`
* Renames the `$list` parameter to `$input_list` in:
* `wp_parse_list()`
* `wp_parse_id_list()`
* `wp_parse_slug_list()`
* `wp_filter_object_list()`
* `wp_list_filter()`
* `wp_list_pluck()`
* `wp_list_sort()`
* Renames the `$array` parameter to `$input_array` in:
* `add_magic_quotes()`
* `wp_array_slice_assoc()`
* `_wp_array_get()`
* `_wp_array_set()`
* Renames the `$function` parameter to `$function_name` in:
* `_deprecated_function()`
* `_deprecated_argument()`
* `_doing_it_wrong()`
* Renames the `$class` parameter to `$class_name` in `_deprecated_constructor()`.
* Renames the `$default` parameter to `$default_value` in `apache_mod_loaded()`.
* Renames the `$var` parameter to `$value` in `wp_validate_boolean()`.
* Amends the `$input` parameter in `wp_parse_str()` for consistency.
Follow-up to [52946], [52996], [52997], [52998], [53003], [53014], [53029], [53039], [53116], [53117], [53137], [53174], [53184], [53185], [53192], [53193], [53198], [53203], [53207], [53215], [53216], [53220], [53230], [53232], [53236], [53239], [53240], [53242], [53243], [53245], [53246], [53257], [53269], [53270], [53271], [53272], [53273], [53274], [53275], [53276], [53277], [53281], [53283], [53284], [53285], [53287], [53364], [53365], [54927].
Props jrf, aristath, poena, justinahinon, SergeyBiryukov.
See #56788.
Built from https://develop.svn.wordpress.org/trunk@54929
git-svn-id: http://core.svn.wordpress.org/trunk@54481 1a063a9b-81f0-0310-95a4-ce76da25c4cd
2022-12-03 10:07:14 -05:00
* @ param string $input_string The string which is to be converted .
2014-10-28 17:29:23 -04:00
* @ return string The checked string .
2014-10-28 14:35:19 -04:00
*/
Code Modernization: Rename parameters that use reserved keywords in `wp-includes/functions.php`.
While using reserved PHP keywords as parameter name labels is allowed, in the context of function calls using named parameters in PHP 8.0+, this will easily lead to confusion. To avoid that, it is recommended not to use reserved keywords as function parameter names.
This commit:
* Renames the `$echo` parameter to `$display` in:
* `wp_nonce_field()`
* `wp_referer_field()`
* `wp_original_referer_field()`
* Renames the `$string` parameter to `$input_string` in
* `_wp_json_convert_string()`
* `_wp_to_kebab_case()`
* Renames the `$list` parameter to `$input_list` in:
* `wp_parse_list()`
* `wp_parse_id_list()`
* `wp_parse_slug_list()`
* `wp_filter_object_list()`
* `wp_list_filter()`
* `wp_list_pluck()`
* `wp_list_sort()`
* Renames the `$array` parameter to `$input_array` in:
* `add_magic_quotes()`
* `wp_array_slice_assoc()`
* `_wp_array_get()`
* `_wp_array_set()`
* Renames the `$function` parameter to `$function_name` in:
* `_deprecated_function()`
* `_deprecated_argument()`
* `_doing_it_wrong()`
* Renames the `$class` parameter to `$class_name` in `_deprecated_constructor()`.
* Renames the `$default` parameter to `$default_value` in `apache_mod_loaded()`.
* Renames the `$var` parameter to `$value` in `wp_validate_boolean()`.
* Amends the `$input` parameter in `wp_parse_str()` for consistency.
Follow-up to [52946], [52996], [52997], [52998], [53003], [53014], [53029], [53039], [53116], [53117], [53137], [53174], [53184], [53185], [53192], [53193], [53198], [53203], [53207], [53215], [53216], [53220], [53230], [53232], [53236], [53239], [53240], [53242], [53243], [53245], [53246], [53257], [53269], [53270], [53271], [53272], [53273], [53274], [53275], [53276], [53277], [53281], [53283], [53284], [53285], [53287], [53364], [53365], [54927].
Props jrf, aristath, poena, justinahinon, SergeyBiryukov.
See #56788.
Built from https://develop.svn.wordpress.org/trunk@54929
git-svn-id: http://core.svn.wordpress.org/trunk@54481 1a063a9b-81f0-0310-95a4-ce76da25c4cd
2022-12-03 10:07:14 -05:00
function _wp_json_convert_string ( $input_string ) {
2014-10-28 14:35:19 -04:00
static $use_mb = null ;
if ( is_null ( $use_mb ) ) {
$use_mb = function_exists ( 'mb_convert_encoding' );
}
if ( $use_mb ) {
Code Modernization: Rename parameters that use reserved keywords in `wp-includes/functions.php`.
While using reserved PHP keywords as parameter name labels is allowed, in the context of function calls using named parameters in PHP 8.0+, this will easily lead to confusion. To avoid that, it is recommended not to use reserved keywords as function parameter names.
This commit:
* Renames the `$echo` parameter to `$display` in:
* `wp_nonce_field()`
* `wp_referer_field()`
* `wp_original_referer_field()`
* Renames the `$string` parameter to `$input_string` in
* `_wp_json_convert_string()`
* `_wp_to_kebab_case()`
* Renames the `$list` parameter to `$input_list` in:
* `wp_parse_list()`
* `wp_parse_id_list()`
* `wp_parse_slug_list()`
* `wp_filter_object_list()`
* `wp_list_filter()`
* `wp_list_pluck()`
* `wp_list_sort()`
* Renames the `$array` parameter to `$input_array` in:
* `add_magic_quotes()`
* `wp_array_slice_assoc()`
* `_wp_array_get()`
* `_wp_array_set()`
* Renames the `$function` parameter to `$function_name` in:
* `_deprecated_function()`
* `_deprecated_argument()`
* `_doing_it_wrong()`
* Renames the `$class` parameter to `$class_name` in `_deprecated_constructor()`.
* Renames the `$default` parameter to `$default_value` in `apache_mod_loaded()`.
* Renames the `$var` parameter to `$value` in `wp_validate_boolean()`.
* Amends the `$input` parameter in `wp_parse_str()` for consistency.
Follow-up to [52946], [52996], [52997], [52998], [53003], [53014], [53029], [53039], [53116], [53117], [53137], [53174], [53184], [53185], [53192], [53193], [53198], [53203], [53207], [53215], [53216], [53220], [53230], [53232], [53236], [53239], [53240], [53242], [53243], [53245], [53246], [53257], [53269], [53270], [53271], [53272], [53273], [53274], [53275], [53276], [53277], [53281], [53283], [53284], [53285], [53287], [53364], [53365], [54927].
Props jrf, aristath, poena, justinahinon, SergeyBiryukov.
See #56788.
Built from https://develop.svn.wordpress.org/trunk@54929
git-svn-id: http://core.svn.wordpress.org/trunk@54481 1a063a9b-81f0-0310-95a4-ce76da25c4cd
2022-12-03 10:07:14 -05:00
$encoding = mb_detect_encoding ( $input_string , mb_detect_order (), true );
2014-10-28 14:35:19 -04:00
if ( $encoding ) {
Code Modernization: Rename parameters that use reserved keywords in `wp-includes/functions.php`.
While using reserved PHP keywords as parameter name labels is allowed, in the context of function calls using named parameters in PHP 8.0+, this will easily lead to confusion. To avoid that, it is recommended not to use reserved keywords as function parameter names.
This commit:
* Renames the `$echo` parameter to `$display` in:
* `wp_nonce_field()`
* `wp_referer_field()`
* `wp_original_referer_field()`
* Renames the `$string` parameter to `$input_string` in
* `_wp_json_convert_string()`
* `_wp_to_kebab_case()`
* Renames the `$list` parameter to `$input_list` in:
* `wp_parse_list()`
* `wp_parse_id_list()`
* `wp_parse_slug_list()`
* `wp_filter_object_list()`
* `wp_list_filter()`
* `wp_list_pluck()`
* `wp_list_sort()`
* Renames the `$array` parameter to `$input_array` in:
* `add_magic_quotes()`
* `wp_array_slice_assoc()`
* `_wp_array_get()`
* `_wp_array_set()`
* Renames the `$function` parameter to `$function_name` in:
* `_deprecated_function()`
* `_deprecated_argument()`
* `_doing_it_wrong()`
* Renames the `$class` parameter to `$class_name` in `_deprecated_constructor()`.
* Renames the `$default` parameter to `$default_value` in `apache_mod_loaded()`.
* Renames the `$var` parameter to `$value` in `wp_validate_boolean()`.
* Amends the `$input` parameter in `wp_parse_str()` for consistency.
Follow-up to [52946], [52996], [52997], [52998], [53003], [53014], [53029], [53039], [53116], [53117], [53137], [53174], [53184], [53185], [53192], [53193], [53198], [53203], [53207], [53215], [53216], [53220], [53230], [53232], [53236], [53239], [53240], [53242], [53243], [53245], [53246], [53257], [53269], [53270], [53271], [53272], [53273], [53274], [53275], [53276], [53277], [53281], [53283], [53284], [53285], [53287], [53364], [53365], [54927].
Props jrf, aristath, poena, justinahinon, SergeyBiryukov.
See #56788.
Built from https://develop.svn.wordpress.org/trunk@54929
git-svn-id: http://core.svn.wordpress.org/trunk@54481 1a063a9b-81f0-0310-95a4-ce76da25c4cd
2022-12-03 10:07:14 -05:00
return mb_convert_encoding ( $input_string , 'UTF-8' , $encoding );
2014-10-28 14:35:19 -04:00
} else {
Code Modernization: Rename parameters that use reserved keywords in `wp-includes/functions.php`.
While using reserved PHP keywords as parameter name labels is allowed, in the context of function calls using named parameters in PHP 8.0+, this will easily lead to confusion. To avoid that, it is recommended not to use reserved keywords as function parameter names.
This commit:
* Renames the `$echo` parameter to `$display` in:
* `wp_nonce_field()`
* `wp_referer_field()`
* `wp_original_referer_field()`
* Renames the `$string` parameter to `$input_string` in
* `_wp_json_convert_string()`
* `_wp_to_kebab_case()`
* Renames the `$list` parameter to `$input_list` in:
* `wp_parse_list()`
* `wp_parse_id_list()`
* `wp_parse_slug_list()`
* `wp_filter_object_list()`
* `wp_list_filter()`
* `wp_list_pluck()`
* `wp_list_sort()`
* Renames the `$array` parameter to `$input_array` in:
* `add_magic_quotes()`
* `wp_array_slice_assoc()`
* `_wp_array_get()`
* `_wp_array_set()`
* Renames the `$function` parameter to `$function_name` in:
* `_deprecated_function()`
* `_deprecated_argument()`
* `_doing_it_wrong()`
* Renames the `$class` parameter to `$class_name` in `_deprecated_constructor()`.
* Renames the `$default` parameter to `$default_value` in `apache_mod_loaded()`.
* Renames the `$var` parameter to `$value` in `wp_validate_boolean()`.
* Amends the `$input` parameter in `wp_parse_str()` for consistency.
Follow-up to [52946], [52996], [52997], [52998], [53003], [53014], [53029], [53039], [53116], [53117], [53137], [53174], [53184], [53185], [53192], [53193], [53198], [53203], [53207], [53215], [53216], [53220], [53230], [53232], [53236], [53239], [53240], [53242], [53243], [53245], [53246], [53257], [53269], [53270], [53271], [53272], [53273], [53274], [53275], [53276], [53277], [53281], [53283], [53284], [53285], [53287], [53364], [53365], [54927].
Props jrf, aristath, poena, justinahinon, SergeyBiryukov.
See #56788.
Built from https://develop.svn.wordpress.org/trunk@54929
git-svn-id: http://core.svn.wordpress.org/trunk@54481 1a063a9b-81f0-0310-95a4-ce76da25c4cd
2022-12-03 10:07:14 -05:00
return mb_convert_encoding ( $input_string , 'UTF-8' , 'UTF-8' );
2014-10-28 14:35:19 -04:00
}
} else {
Code Modernization: Rename parameters that use reserved keywords in `wp-includes/functions.php`.
While using reserved PHP keywords as parameter name labels is allowed, in the context of function calls using named parameters in PHP 8.0+, this will easily lead to confusion. To avoid that, it is recommended not to use reserved keywords as function parameter names.
This commit:
* Renames the `$echo` parameter to `$display` in:
* `wp_nonce_field()`
* `wp_referer_field()`
* `wp_original_referer_field()`
* Renames the `$string` parameter to `$input_string` in
* `_wp_json_convert_string()`
* `_wp_to_kebab_case()`
* Renames the `$list` parameter to `$input_list` in:
* `wp_parse_list()`
* `wp_parse_id_list()`
* `wp_parse_slug_list()`
* `wp_filter_object_list()`
* `wp_list_filter()`
* `wp_list_pluck()`
* `wp_list_sort()`
* Renames the `$array` parameter to `$input_array` in:
* `add_magic_quotes()`
* `wp_array_slice_assoc()`
* `_wp_array_get()`
* `_wp_array_set()`
* Renames the `$function` parameter to `$function_name` in:
* `_deprecated_function()`
* `_deprecated_argument()`
* `_doing_it_wrong()`
* Renames the `$class` parameter to `$class_name` in `_deprecated_constructor()`.
* Renames the `$default` parameter to `$default_value` in `apache_mod_loaded()`.
* Renames the `$var` parameter to `$value` in `wp_validate_boolean()`.
* Amends the `$input` parameter in `wp_parse_str()` for consistency.
Follow-up to [52946], [52996], [52997], [52998], [53003], [53014], [53029], [53039], [53116], [53117], [53137], [53174], [53184], [53185], [53192], [53193], [53198], [53203], [53207], [53215], [53216], [53220], [53230], [53232], [53236], [53239], [53240], [53242], [53243], [53245], [53246], [53257], [53269], [53270], [53271], [53272], [53273], [53274], [53275], [53276], [53277], [53281], [53283], [53284], [53285], [53287], [53364], [53365], [54927].
Props jrf, aristath, poena, justinahinon, SergeyBiryukov.
See #56788.
Built from https://develop.svn.wordpress.org/trunk@54929
git-svn-id: http://core.svn.wordpress.org/trunk@54481 1a063a9b-81f0-0310-95a4-ce76da25c4cd
2022-12-03 10:07:14 -05:00
return wp_check_invalid_utf8 ( $input_string , true );
2014-10-28 14:35:19 -04:00
}
}
2015-10-07 21:30:25 -04:00
/**
* Prepares response data to be serialized to JSON .
*
* This supports the JsonSerializable interface for PHP 5.2 - 5.3 as well .
*
* @ ignore
2020-01-28 19:45:18 -05:00
* @ since 4.4 . 0
2019-09-20 16:08:57 -04:00
* @ deprecated 5.3 . 0 This function is no longer needed as support for PHP 5.2 - 5.3
* has been dropped .
2020-06-20 08:02:12 -04:00
* @ access private
2015-10-07 21:30:25 -04:00
*
* @ param mixed $data Native representation .
* @ return bool | int | float | null | string | array Data ready for `json_encode()` .
*/
function _wp_json_prepare_data ( $data ) {
2019-09-20 16:08:57 -04:00
_deprecated_function ( __FUNCTION__ , '5.3.0' );
return $data ;
2015-10-07 21:30:25 -04:00
}
2012-08-30 21:56:00 -04:00
/**
2022-08-12 05:53:11 -04:00
* Sends a JSON response back to an Ajax request .
2012-08-30 21:56:00 -04:00
*
* @ since 3.5 . 0
2016-08-28 13:42:28 -04:00
* @ since 4.7 . 0 The `$status_code` parameter was added .
2020-10-20 11:56:08 -04:00
* @ since 5.6 . 0 The `$options` parameter was added .
2012-08-30 21:56:00 -04:00
*
2016-08-28 13:42:28 -04:00
* @ param mixed $response Variable ( usually an array or object ) to encode as JSON ,
* then print and die .
2020-10-20 11:56:08 -04:00
* @ param int $status_code Optional . The HTTP status code to output . Default null .
* @ param int $options Optional . Options to be passed to json_encode () . Default 0.
2012-08-30 21:56:00 -04:00
*/
2020-10-20 11:56:08 -04:00
function wp_send_json ( $response , $status_code = null , $options = 0 ) {
2020-07-07 01:01:07 -04:00
if ( defined ( 'REST_REQUEST' ) && REST_REQUEST ) {
2020-07-07 05:56:02 -04:00
_doing_it_wrong (
__FUNCTION__ ,
sprintf (
/* translators: 1: WP_REST_Response, 2: WP_Error */
__ ( 'Return a %1$s or %2$s object from your callback when using the REST API.' ),
'WP_REST_Response' ,
'WP_Error'
),
'5.5.0'
);
2020-07-07 01:01:07 -04:00
}
2019-07-09 01:45:58 -04:00
if ( ! headers_sent () ) {
header ( 'Content-Type: application/json; charset=' . get_option ( 'blog_charset' ) );
if ( null !== $status_code ) {
status_header ( $status_code );
}
2016-09-08 09:45:34 -04:00
}
2019-07-09 01:45:58 -04:00
2020-10-20 11:56:08 -04:00
echo wp_json_encode ( $response , $options );
2016-10-26 10:32:28 -04:00
if ( wp_doing_ajax () ) {
2017-11-30 18:11:00 -05:00
wp_die (
2018-08-16 21:51:36 -04:00
'' ,
'' ,
array (
2017-11-30 18:11:00 -05:00
'response' => null ,
)
);
2016-10-26 10:32:28 -04:00
} else {
2012-08-30 21:56:00 -04:00
die ;
2016-10-26 10:32:28 -04:00
}
2012-08-30 21:56:00 -04:00
}
/**
2022-08-12 05:53:11 -04:00
* Sends a JSON response back to an Ajax request , indicating success .
2012-08-30 21:56:00 -04:00
*
* @ since 3.5 . 0
2016-08-28 13:42:28 -04:00
* @ since 4.7 . 0 The `$status_code` parameter was added .
2020-10-20 11:56:08 -04:00
* @ since 5.6 . 0 The `$options` parameter was added .
2012-08-30 21:56:00 -04:00
*
2020-10-20 11:56:08 -04:00
* @ param mixed $data Optional . Data to encode as JSON , then print and die . Default null .
* @ param int $status_code Optional . The HTTP status code to output . Default null .
* @ param int $options Optional . Options to be passed to json_encode () . Default 0.
2012-08-30 21:56:00 -04:00
*/
2020-10-20 11:56:08 -04:00
function wp_send_json_success ( $data = null , $status_code = null , $options = 0 ) {
2012-08-30 21:56:00 -04:00
$response = array ( 'success' => true );
2017-11-30 18:11:00 -05:00
if ( isset ( $data ) ) {
2012-08-30 21:56:00 -04:00
$response [ 'data' ] = $data ;
2017-11-30 18:11:00 -05:00
}
2012-08-30 21:56:00 -04:00
2020-10-20 11:56:08 -04:00
wp_send_json ( $response , $status_code , $options );
2012-08-30 21:56:00 -04:00
}
/**
2022-08-12 05:53:11 -04:00
* Sends a JSON response back to an Ajax request , indicating failure .
2012-08-30 21:56:00 -04:00
*
2016-05-02 00:00:28 -04:00
* If the `$data` parameter is a WP_Error object , the errors
2014-11-28 06:39:22 -05:00
* within the object are processed and output as an array of error
* codes and corresponding messages . All other types are output
* without further processing .
2014-11-21 11:56:23 -05:00
*
2012-08-30 21:56:00 -04:00
* @ since 3.5 . 0
2016-05-02 00:00:28 -04:00
* @ since 4.1 . 0 The `$data` parameter is now processed if a WP_Error object is passed in .
2016-08-28 13:42:28 -04:00
* @ since 4.7 . 0 The `$status_code` parameter was added .
2020-10-20 11:56:08 -04:00
* @ since 5.6 . 0 The `$options` parameter was added .
2012-08-30 21:56:00 -04:00
*
2020-10-20 11:56:08 -04:00
* @ param mixed $data Optional . Data to encode as JSON , then print and die . Default null .
* @ param int $status_code Optional . The HTTP status code to output . Default null .
* @ param int $options Optional . Options to be passed to json_encode () . Default 0.
2012-08-30 21:56:00 -04:00
*/
2020-10-20 11:56:08 -04:00
function wp_send_json_error ( $data = null , $status_code = null , $options = 0 ) {
2012-08-30 21:56:00 -04:00
$response = array ( 'success' => false );
2014-11-21 11:56:23 -05:00
if ( isset ( $data ) ) {
if ( is_wp_error ( $data ) ) {
$result = array ();
foreach ( $data -> errors as $code => $messages ) {
foreach ( $messages as $message ) {
2017-11-30 18:11:00 -05:00
$result [] = array (
'code' => $code ,
'message' => $message ,
);
2014-11-21 11:56:23 -05:00
}
}
$response [ 'data' ] = $result ;
} else {
$response [ 'data' ] = $data ;
}
}
2012-08-30 21:56:00 -04:00
2020-10-20 11:56:08 -04:00
wp_send_json ( $response , $status_code , $options );
2012-08-30 21:56:00 -04:00
}
2016-06-06 17:34:28 -04:00
/**
2020-07-14 07:56:04 -04:00
* Checks that a JSONP callback is a valid JavaScript callback name .
2016-06-06 17:34:28 -04:00
*
* Only allows alphanumeric characters and the dot character in callback
* function names . This helps to mitigate XSS attacks caused by directly
* outputting user input .
*
* @ since 4.6 . 0
*
2020-07-14 07:56:04 -04:00
* @ param string $callback Supplied JSONP callback function name .
* @ return bool Whether the callback function name is valid .
2016-06-06 17:34:28 -04:00
*/
function wp_check_jsonp_callback ( $callback ) {
if ( ! is_string ( $callback ) ) {
return false ;
}
2016-08-22 16:51:30 -04:00
preg_replace ( '/[^\w\.]/' , '' , $callback , - 1 , $illegal_char_count );
2016-06-06 17:34:28 -04:00
return 0 === $illegal_char_count ;
}
2021-08-11 05:08:01 -04:00
/**
* Reads and decodes a JSON file .
*
* @ since 5.9 . 0
*
* @ param string $filename Path to the JSON file .
* @ param array $options {
* Optional . Options to be used with `json_decode()` .
*
2022-04-29 15:24:09 -04:00
* @ type bool $associative Optional . When `true` , JSON objects will be returned as associative arrays .
2023-02-21 11:39:19 -05:00
* When `false` , JSON objects will be returned as objects . Default false .
2021-08-11 05:08:01 -04:00
* }
*
* @ return mixed Returns the value encoded in JSON in appropriate PHP type .
* `null` is returned if the file is not found , or its content can ' t be decoded .
*/
function wp_json_file_decode ( $filename , $options = array () ) {
$result = null ;
$filename = wp_normalize_path ( realpath ( $filename ) );
General: Remove `file_exists()` checks after calling `realpath()`.
`realpath()` already checks if the file exists, and returns `false` on failure. The additional `file_exists()` check is not necessary and can be removed, improving the performance.
This commit simplifies the checks in two functions:
* `register_block_type_from_metadata()`
* `wp_json_file_decode()`
Note: In both of these cases, the values are passed through `wp_normalize_path()` after `realpath()`, so if the file does not exist, the `false` value gets converted to an empty string. The updated checks work both for `false` and `''` values.
Though this is a small tweak, it saves a lot of checks since one of the places we do this is when registering block styles, so it runs quite a few times on each page load.
Reference: [https://www.php.net/manual/en/function.realpath.php PHP Manual: realpath()].
Follow-up to [51599], [54132], [54290], [54291].
Props aristath.
Fixes #56654.
Built from https://develop.svn.wordpress.org/trunk@54309
git-svn-id: http://core.svn.wordpress.org/trunk@53868 1a063a9b-81f0-0310-95a4-ce76da25c4cd
2022-09-26 09:07:14 -04:00
if ( ! $filename ) {
2021-08-11 05:08:01 -04:00
trigger_error (
sprintf (
/* translators: %s: Path to the JSON file. */
__ ( " File %s doesn't exist! " ),
$filename
)
);
return $result ;
}
$options = wp_parse_args ( $options , array ( 'associative' => false ) );
$decoded_file = json_decode ( file_get_contents ( $filename ), $options [ 'associative' ] );
if ( JSON_ERROR_NONE !== json_last_error () ) {
trigger_error (
sprintf (
/* translators: 1: Path to the JSON file, 2: Error message. */
__ ( 'Error when decoding a JSON file at path %1$s: %2$s' ),
$filename ,
json_last_error_msg ()
)
);
return $result ;
}
return $decoded_file ;
}
2008-08-09 00:51:51 -04:00
/**
2022-08-12 05:53:11 -04:00
* Retrieves the WordPress home page URL .
2008-08-09 00:51:51 -04:00
*
2014-06-30 21:44:15 -04:00
* If the constant named 'WP_HOME' exists , then it will be used and returned
* by the function . This can be used to counter the redirection on your local
2008-08-09 00:51:51 -04:00
* development environment .
*
* @ since 2.2 . 0
2014-06-30 21:44:15 -04:00
* @ access private
2008-08-09 00:51:51 -04:00
*
2014-06-30 21:44:15 -04:00
* @ see WP_HOME
*
* @ param string $url URL for the home location .
2008-08-09 00:51:51 -04:00
* @ return string Homepage location .
*/
2007-10-11 01:46:57 -04:00
function _config_wp_home ( $url = '' ) {
2017-11-30 18:11:00 -05:00
if ( defined ( 'WP_HOME' ) ) {
2011-07-21 17:35:23 -04:00
return untrailingslashit ( WP_HOME );
2017-11-30 18:11:00 -05:00
}
2007-10-11 01:46:57 -04:00
return $url ;
2007-03-23 13:45:40 -04:00
}
2008-08-09 00:51:51 -04:00
/**
2022-08-12 05:53:11 -04:00
* Retrieves the WordPress site URL .
2008-08-09 00:51:51 -04:00
*
* If the constant named 'WP_SITEURL' is defined , then the value in that
2014-06-30 21:44:15 -04:00
* constant will always be returned . This can be used for debugging a site
* on your localhost while not having to change the database to your URL .
2008-08-09 00:51:51 -04:00
*
* @ since 2.2 . 0
2014-06-30 21:44:15 -04:00
* @ access private
*
* @ see WP_SITEURL
2008-08-09 00:51:51 -04:00
*
* @ param string $url URL to set the WordPress site location .
2022-04-15 07:58:10 -04:00
* @ return string The WordPress site URL .
2008-08-09 00:51:51 -04:00
*/
2007-10-11 01:46:57 -04:00
function _config_wp_siteurl ( $url = '' ) {
2017-11-30 18:11:00 -05:00
if ( defined ( 'WP_SITEURL' ) ) {
2011-07-21 17:35:23 -04:00
return untrailingslashit ( WP_SITEURL );
2017-11-30 18:11:00 -05:00
}
2007-10-11 01:46:57 -04:00
return $url ;
2007-03-23 13:45:40 -04:00
}
Customize: Introduce starter content and site freshness state.
A theme can opt-in for tailored starter content to apply to the customizer when previewing the theme on a fresh install, when `fresh_site` is at its initial `1` value. Starter content is staged in the customizer and does not go live unless the changes are published. Initial starter content is added to Twenty Seventeen.
* The `fresh_site` flag is cleared when a published post or page is saved, when widgets are modified, or when the customizer state is saved.
* Starter content is registered via `starter-content` theme support, where the argument is an array containing `widgets`, `posts`, `nav_menus`, `options`, and `theme_mods`. Posts/pages in starter content are created with the `auto-draft` status, re-using the page/post stubs feature added to nav menus and the static front page controls.
* A `get_theme_starter_content` filter allows for plugins to extend a theme's starter content.
* Starter content in themes can/should re-use existing starter content items in core by using named placeholders.
* Import theme starter content into customized state when fresh site.
* Prevent original_title differences from causing refreshes if title is present.
* Ensure nav menu item url is set according to object when previewing.
* Make sure initial saved state is false if there are dirty settings without an existing changeset.
* Ensure dirty settings are cleaned upon changeset publishing.
Props helen, westonruter, ocean90.
Fixes #38114, #38533.
Built from https://develop.svn.wordpress.org/trunk@38991
git-svn-id: http://core.svn.wordpress.org/trunk@38934 1a063a9b-81f0-0310-95a4-ce76da25c4cd
2016-10-27 22:57:35 -04:00
/**
2022-08-12 05:53:11 -04:00
* Deletes the fresh site option .
Customize: Introduce starter content and site freshness state.
A theme can opt-in for tailored starter content to apply to the customizer when previewing the theme on a fresh install, when `fresh_site` is at its initial `1` value. Starter content is staged in the customizer and does not go live unless the changes are published. Initial starter content is added to Twenty Seventeen.
* The `fresh_site` flag is cleared when a published post or page is saved, when widgets are modified, or when the customizer state is saved.
* Starter content is registered via `starter-content` theme support, where the argument is an array containing `widgets`, `posts`, `nav_menus`, `options`, and `theme_mods`. Posts/pages in starter content are created with the `auto-draft` status, re-using the page/post stubs feature added to nav menus and the static front page controls.
* A `get_theme_starter_content` filter allows for plugins to extend a theme's starter content.
* Starter content in themes can/should re-use existing starter content items in core by using named placeholders.
* Import theme starter content into customized state when fresh site.
* Prevent original_title differences from causing refreshes if title is present.
* Ensure nav menu item url is set according to object when previewing.
* Make sure initial saved state is false if there are dirty settings without an existing changeset.
* Ensure dirty settings are cleaned upon changeset publishing.
Props helen, westonruter, ocean90.
Fixes #38114, #38533.
Built from https://develop.svn.wordpress.org/trunk@38991
git-svn-id: http://core.svn.wordpress.org/trunk@38934 1a063a9b-81f0-0310-95a4-ce76da25c4cd
2016-10-27 22:57:35 -04:00
*
* @ since 4.7 . 0
* @ access private
*/
function _delete_option_fresh_site () {
2017-08-12 20:57:43 -04:00
update_option ( 'fresh_site' , '0' );
Customize: Introduce starter content and site freshness state.
A theme can opt-in for tailored starter content to apply to the customizer when previewing the theme on a fresh install, when `fresh_site` is at its initial `1` value. Starter content is staged in the customizer and does not go live unless the changes are published. Initial starter content is added to Twenty Seventeen.
* The `fresh_site` flag is cleared when a published post or page is saved, when widgets are modified, or when the customizer state is saved.
* Starter content is registered via `starter-content` theme support, where the argument is an array containing `widgets`, `posts`, `nav_menus`, `options`, and `theme_mods`. Posts/pages in starter content are created with the `auto-draft` status, re-using the page/post stubs feature added to nav menus and the static front page controls.
* A `get_theme_starter_content` filter allows for plugins to extend a theme's starter content.
* Starter content in themes can/should re-use existing starter content items in core by using named placeholders.
* Import theme starter content into customized state when fresh site.
* Prevent original_title differences from causing refreshes if title is present.
* Ensure nav menu item url is set according to object when previewing.
* Make sure initial saved state is false if there are dirty settings without an existing changeset.
* Ensure dirty settings are cleaned upon changeset publishing.
Props helen, westonruter, ocean90.
Fixes #38114, #38533.
Built from https://develop.svn.wordpress.org/trunk@38991
git-svn-id: http://core.svn.wordpress.org/trunk@38934 1a063a9b-81f0-0310-95a4-ce76da25c4cd
2016-10-27 22:57:35 -04:00
}
2008-08-09 00:51:51 -04:00
/**
2022-08-12 05:53:11 -04:00
* Sets the localized direction for MCE plugin .
2008-08-09 00:51:51 -04:00
*
2014-06-30 21:44:15 -04:00
* Will only set the direction to 'rtl' , if the WordPress locale has
* the text direction set to 'rtl' .
2008-08-09 00:51:51 -04:00
*
2014-06-30 21:44:15 -04:00
* Fills in the 'directionality' setting , enables the 'directionality'
* plugin , and adds the 'ltr' button to 'toolbar1' , formerly
* 'theme_advanced_buttons1' array keys . These keys are then returned
2016-08-24 21:20:30 -04:00
* in the $mce_init ( TinyMCE settings ) array .
2008-08-09 00:51:51 -04:00
*
* @ since 2.1 . 0
2014-06-30 21:44:15 -04:00
* @ access private
2008-08-09 00:51:51 -04:00
*
2016-08-24 21:20:30 -04:00
* @ param array $mce_init MCE settings array .
2008-08-09 00:51:51 -04:00
* @ return array Direction set for 'rtl' , if needed by locale .
*/
2016-08-24 21:20:30 -04:00
function _mce_set_direction ( $mce_init ) {
2010-05-03 01:49:19 -04:00
if ( is_rtl () ) {
2016-08-24 21:20:30 -04:00
$mce_init [ 'directionality' ] = 'rtl' ;
2017-11-30 18:11:00 -05:00
$mce_init [ 'rtl_ui' ] = true ;
2015-03-24 16:33:27 -04: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 10:36:26 -04:00
if ( ! empty ( $mce_init [ 'plugins' ] ) && ! str_contains ( $mce_init [ 'plugins' ], 'directionality' ) ) {
2016-08-24 21:20:30 -04:00
$mce_init [ 'plugins' ] .= ',directionality' ;
2015-03-24 16:33:27 -04:00
}
2016-08-24 21:20:30 -04:00
if ( ! empty ( $mce_init [ 'toolbar1' ] ) && ! preg_match ( '/\bltr\b/' , $mce_init [ 'toolbar1' ] ) ) {
$mce_init [ 'toolbar1' ] .= ',ltr' ;
2015-03-24 16:33:27 -04:00
}
2006-09-20 20:34:34 -04:00
}
2016-08-24 21:20:30 -04:00
return $mce_init ;
2006-09-20 20:34:34 -04:00
}
2007-03-12 17:31:24 -04:00
2013-11-14 21:46:10 -05:00
2008-08-09 00:51:51 -04:00
/**
2022-08-12 05:53:11 -04:00
* Converts smiley code to the icon graphic file equivalent .
2008-08-09 00:51:51 -04:00
*
* You can turn off smilies , by going to the write setting screen and unchecking
* the box , or by setting 'use_smilies' option to false or removing the option .
*
* Plugins may override the default smiley list by setting the $wpsmiliestrans
* to an array , with the key the code the blogger types in and the value the
* image file .
*
2009-01-06 13:20:47 -05:00
* The $wp_smiliessearch global is for the regular expression and is set each
* time the function is called .
2008-08-09 00:51:51 -04:00
*
* The full list of smilies can be found in the function and won ' t be listed in
* the description . Probably should create a Codex page for it , so that it is
* available .
*
* @ global array $wpsmiliestrans
* @ global array $wp_smiliessearch
2014-06-30 21:44:15 -04:00
*
2008-08-09 00:51:51 -04:00
* @ since 2.2 . 0
*/
2007-03-12 17:31:24 -04:00
function smilies_init () {
2009-01-06 13:20:47 -05:00
global $wpsmiliestrans , $wp_smiliessearch ;
2007-03-12 17:31:24 -04:00
2020-01-28 19:45:18 -05:00
// Don't bother setting up smilies if they are disabled.
2017-11-30 18:11:00 -05:00
if ( ! get_option ( 'use_smilies' ) ) {
2007-03-12 17:31:24 -04:00
return ;
2017-11-30 18:11:00 -05:00
}
2007-03-12 17:31:24 -04:00
2017-11-30 18:11:00 -05:00
if ( ! isset ( $wpsmiliestrans ) ) {
2007-03-12 17:31:24 -04:00
$wpsmiliestrans = array (
2017-11-30 18:11:00 -05:00
':mrgreen:' => 'mrgreen.png' ,
':neutral:' => " \xf0 \x9f \x98 \x90 " ,
':twisted:' => " \xf0 \x9f \x98 \x88 " ,
':arrow:' => " \xe2 \x9e \xa1 " ,
':shock:' => " \xf0 \x9f \x98 \xaf " ,
':smile:' => " \xf0 \x9f \x99 \x82 " ,
':???:' => " \xf0 \x9f \x98 \x95 " ,
':cool:' => " \xf0 \x9f \x98 \x8e " ,
':evil:' => " \xf0 \x9f \x91 \xbf " ,
':grin:' => " \xf0 \x9f \x98 \x80 " ,
':idea:' => " \xf0 \x9f \x92 \xa1 " ,
':oops:' => " \xf0 \x9f \x98 \xb3 " ,
':razz:' => " \xf0 \x9f \x98 \x9b " ,
':roll:' => " \xf0 \x9f \x99 \x84 " ,
':wink:' => " \xf0 \x9f \x98 \x89 " ,
':cry:' => " \xf0 \x9f \x98 \xa5 " ,
':eek:' => " \xf0 \x9f \x98 \xae " ,
':lol:' => " \xf0 \x9f \x98 \x86 " ,
':mad:' => " \xf0 \x9f \x98 \xa1 " ,
':sad:' => " \xf0 \x9f \x99 \x81 " ,
'8-)' => " \xf0 \x9f \x98 \x8e " ,
'8-O' => " \xf0 \x9f \x98 \xaf " ,
':-(' => " \xf0 \x9f \x99 \x81 " ,
':-)' => " \xf0 \x9f \x99 \x82 " ,
':-?' => " \xf0 \x9f \x98 \x95 " ,
':-D' => " \xf0 \x9f \x98 \x80 " ,
':-P' => " \xf0 \x9f \x98 \x9b " ,
':-o' => " \xf0 \x9f \x98 \xae " ,
':-x' => " \xf0 \x9f \x98 \xa1 " ,
':-|' => " \xf0 \x9f \x98 \x90 " ,
';-)' => " \xf0 \x9f \x98 \x89 " ,
// This one transformation breaks regular text with frequency.
// '8)' => "\xf0\x9f\x98\x8e",
'8O' => " \xf0 \x9f \x98 \xaf " ,
':(' => " \xf0 \x9f \x99 \x81 " ,
':)' => " \xf0 \x9f \x99 \x82 " ,
':?' => " \xf0 \x9f \x98 \x95 " ,
':D' => " \xf0 \x9f \x98 \x80 " ,
':P' => " \xf0 \x9f \x98 \x9b " ,
':o' => " \xf0 \x9f \x98 \xae " ,
':x' => " \xf0 \x9f \x98 \xa1 " ,
':|' => " \xf0 \x9f \x98 \x90 " ,
';)' => " \xf0 \x9f \x98 \x89 " ,
':!:' => " \xe2 \x9d \x97 " ,
':?:' => " \xe2 \x9d \x93 " ,
2007-03-12 17:31:24 -04:00
);
}
2016-09-01 20:00:30 -04:00
/**
2016-09-14 17:53:29 -04:00
* Filters all the smilies .
2016-09-01 20:00:30 -04:00
*
* This filter must be added before `smilies_init` is run , as
* it is normally only run once to setup the smilies regex .
*
2016-09-01 20:08:30 -04:00
* @ since 4.7 . 0
2016-09-01 20:00:30 -04:00
*
2019-10-26 17:09:04 -04:00
* @ param string [] $wpsmiliestrans List of the smilies ' hexadecimal representations , keyed by their smily code .
2016-09-01 20:00:30 -04:00
*/
2017-11-30 18:11:00 -05:00
$wpsmiliestrans = apply_filters ( 'smilies' , $wpsmiliestrans );
2016-09-01 20:00:30 -04:00
Coding Standards: Use strict comparison where `count()` is involved.
Follow-up to [1636], [6974], [8114], [10322], [13326], [14760], [18006], [18541], [19743], [23249], [24115], [33359].
Props aristath, poena, afercia, SergeyBiryukov.
See #57839.
Built from https://develop.svn.wordpress.org/trunk@55642
git-svn-id: http://core.svn.wordpress.org/trunk@55154 1a063a9b-81f0-0310-95a4-ce76da25c4cd
2023-04-10 08:56:21 -04:00
if ( count ( $wpsmiliestrans ) === 0 ) {
2009-01-06 13:20:47 -05:00
return ;
}
/*
* NOTE : we sort the smilies in reverse key order . This is to make sure
* we match the longest possible smilie ( : ? ? ? : vs : ? ) as the regular
* expression used below is first - match
*/
2017-11-30 18:11:00 -05:00
krsort ( $wpsmiliestrans );
2009-01-06 13:20:47 -05:00
2014-06-09 22:03:14 -04:00
$spaces = wp_spaces_regexp ();
2020-01-28 19:45:18 -05:00
// Begin first "subpattern".
2014-06-09 22:03:14 -04:00
$wp_smiliessearch = '/(?<=' . $spaces . '|^)' ;
2009-01-06 13:20:47 -05:00
$subchar = '' ;
2007-03-12 17:31:24 -04:00
foreach ( ( array ) $wpsmiliestrans as $smiley => $img ) {
2017-11-30 18:11:00 -05:00
$firstchar = substr ( $smiley , 0 , 1 );
$rest = substr ( $smiley , 1 );
2009-01-06 13:20:47 -05:00
2020-01-28 19:45:18 -05:00
// New subpattern?
2017-11-30 18:11:00 -05:00
if ( $firstchar != $subchar ) {
2020-05-16 14:42:12 -04:00
if ( '' !== $subchar ) {
2020-01-28 19:45:18 -05:00
$wp_smiliessearch .= ')(?=' . $spaces . '|$)' ; // End previous "subpattern".
$wp_smiliessearch .= '|(?<=' . $spaces . '|^)' ; // Begin another "subpattern".
2009-01-06 13:20:47 -05:00
}
2017-11-30 18:11:00 -05:00
$subchar = $firstchar ;
$wp_smiliessearch .= preg_quote ( $firstchar , '/' ) . '(?:' ;
2009-01-06 13:20:47 -05:00
} else {
$wp_smiliessearch .= '|' ;
}
2017-11-30 18:11:00 -05:00
$wp_smiliessearch .= preg_quote ( $rest , '/' );
2007-03-12 17:31:24 -04:00
}
2009-01-06 13:20:47 -05:00
2014-06-09 22:03:14 -04:00
$wp_smiliessearch .= ')(?=' . $spaces . '|$)/m' ;
2013-11-14 21:46:10 -05:00
2007-03-12 17:31:24 -04:00
}
2008-06-15 05:38:32 -04:00
/**
2021-01-06 12:25:07 -05:00
* Merges user defined arguments into defaults array .
2008-06-15 05:38:32 -04:00
*
* This function is used throughout WordPress to allow for both string or array
* to be merged into another array .
*
* @ since 2.2 . 0
2016-09-28 04:41:29 -04:00
* @ since 2.3 . 0 `$args` can now also be an object .
2008-06-15 05:38:32 -04:00
*
2016-09-28 04:41:29 -04:00
* @ param string | array | object $args Value to merge with $defaults .
2020-03-04 07:00:06 -05:00
* @ param array $defaults Optional . Array that serves as the defaults .
* Default empty array .
2008-06-15 05:38:32 -04:00
* @ return array Merged user defined values with defaults .
*/
2020-03-04 07:00:06 -05:00
function wp_parse_args ( $args , $defaults = array () ) {
2017-11-30 18:11:00 -05:00
if ( is_object ( $args ) ) {
2019-07-24 20:48:58 -04:00
$parsed_args = get_object_vars ( $args );
2017-11-30 18:11:00 -05:00
} elseif ( is_array ( $args ) ) {
2019-07-24 20:48:58 -04:00
$parsed_args =& $args ;
2017-11-30 18:11:00 -05:00
} else {
2019-07-24 20:48:58 -04:00
wp_parse_str ( $args , $parsed_args );
2017-11-30 18:11:00 -05:00
}
2007-06-13 22:25:30 -04:00
2020-03-04 07:00:06 -05:00
if ( is_array ( $defaults ) && $defaults ) {
2019-07-24 20:48:58 -04:00
return array_merge ( $defaults , $parsed_args );
2017-11-30 18:11:00 -05:00
}
2019-07-24 20:48:58 -04:00
return $parsed_args ;
2007-04-10 15:52:15 -04:00
}
2019-01-10 16:06:49 -05:00
/**
2021-01-06 12:25:07 -05:00
* Converts a comma - or space - separated list of scalar values to an array .
2019-01-10 16:06:49 -05:00
*
* @ since 5.1 . 0
*
Code Modernization: Rename parameters that use reserved keywords in `wp-includes/functions.php`.
While using reserved PHP keywords as parameter name labels is allowed, in the context of function calls using named parameters in PHP 8.0+, this will easily lead to confusion. To avoid that, it is recommended not to use reserved keywords as function parameter names.
This commit:
* Renames the `$echo` parameter to `$display` in:
* `wp_nonce_field()`
* `wp_referer_field()`
* `wp_original_referer_field()`
* Renames the `$string` parameter to `$input_string` in
* `_wp_json_convert_string()`
* `_wp_to_kebab_case()`
* Renames the `$list` parameter to `$input_list` in:
* `wp_parse_list()`
* `wp_parse_id_list()`
* `wp_parse_slug_list()`
* `wp_filter_object_list()`
* `wp_list_filter()`
* `wp_list_pluck()`
* `wp_list_sort()`
* Renames the `$array` parameter to `$input_array` in:
* `add_magic_quotes()`
* `wp_array_slice_assoc()`
* `_wp_array_get()`
* `_wp_array_set()`
* Renames the `$function` parameter to `$function_name` in:
* `_deprecated_function()`
* `_deprecated_argument()`
* `_doing_it_wrong()`
* Renames the `$class` parameter to `$class_name` in `_deprecated_constructor()`.
* Renames the `$default` parameter to `$default_value` in `apache_mod_loaded()`.
* Renames the `$var` parameter to `$value` in `wp_validate_boolean()`.
* Amends the `$input` parameter in `wp_parse_str()` for consistency.
Follow-up to [52946], [52996], [52997], [52998], [53003], [53014], [53029], [53039], [53116], [53117], [53137], [53174], [53184], [53185], [53192], [53193], [53198], [53203], [53207], [53215], [53216], [53220], [53230], [53232], [53236], [53239], [53240], [53242], [53243], [53245], [53246], [53257], [53269], [53270], [53271], [53272], [53273], [53274], [53275], [53276], [53277], [53281], [53283], [53284], [53285], [53287], [53364], [53365], [54927].
Props jrf, aristath, poena, justinahinon, SergeyBiryukov.
See #56788.
Built from https://develop.svn.wordpress.org/trunk@54929
git-svn-id: http://core.svn.wordpress.org/trunk@54481 1a063a9b-81f0-0310-95a4-ce76da25c4cd
2022-12-03 10:07:14 -05:00
* @ param array | string $input_list List of values .
2021-01-06 12:25:07 -05:00
* @ return array Array of values .
2019-01-10 16:06:49 -05:00
*/
Code Modernization: Rename parameters that use reserved keywords in `wp-includes/functions.php`.
While using reserved PHP keywords as parameter name labels is allowed, in the context of function calls using named parameters in PHP 8.0+, this will easily lead to confusion. To avoid that, it is recommended not to use reserved keywords as function parameter names.
This commit:
* Renames the `$echo` parameter to `$display` in:
* `wp_nonce_field()`
* `wp_referer_field()`
* `wp_original_referer_field()`
* Renames the `$string` parameter to `$input_string` in
* `_wp_json_convert_string()`
* `_wp_to_kebab_case()`
* Renames the `$list` parameter to `$input_list` in:
* `wp_parse_list()`
* `wp_parse_id_list()`
* `wp_parse_slug_list()`
* `wp_filter_object_list()`
* `wp_list_filter()`
* `wp_list_pluck()`
* `wp_list_sort()`
* Renames the `$array` parameter to `$input_array` in:
* `add_magic_quotes()`
* `wp_array_slice_assoc()`
* `_wp_array_get()`
* `_wp_array_set()`
* Renames the `$function` parameter to `$function_name` in:
* `_deprecated_function()`
* `_deprecated_argument()`
* `_doing_it_wrong()`
* Renames the `$class` parameter to `$class_name` in `_deprecated_constructor()`.
* Renames the `$default` parameter to `$default_value` in `apache_mod_loaded()`.
* Renames the `$var` parameter to `$value` in `wp_validate_boolean()`.
* Amends the `$input` parameter in `wp_parse_str()` for consistency.
Follow-up to [52946], [52996], [52997], [52998], [53003], [53014], [53029], [53039], [53116], [53117], [53137], [53174], [53184], [53185], [53192], [53193], [53198], [53203], [53207], [53215], [53216], [53220], [53230], [53232], [53236], [53239], [53240], [53242], [53243], [53245], [53246], [53257], [53269], [53270], [53271], [53272], [53273], [53274], [53275], [53276], [53277], [53281], [53283], [53284], [53285], [53287], [53364], [53365], [54927].
Props jrf, aristath, poena, justinahinon, SergeyBiryukov.
See #56788.
Built from https://develop.svn.wordpress.org/trunk@54929
git-svn-id: http://core.svn.wordpress.org/trunk@54481 1a063a9b-81f0-0310-95a4-ce76da25c4cd
2022-12-03 10:07:14 -05:00
function wp_parse_list ( $input_list ) {
if ( ! is_array ( $input_list ) ) {
return preg_split ( '/[\s,]+/' , $input_list , - 1 , PREG_SPLIT_NO_EMPTY );
2019-01-10 16:06:49 -05:00
}
2022-10-11 09:25:11 -04:00
// Validate all entries of the list are scalar.
Code Modernization: Rename parameters that use reserved keywords in `wp-includes/functions.php`.
While using reserved PHP keywords as parameter name labels is allowed, in the context of function calls using named parameters in PHP 8.0+, this will easily lead to confusion. To avoid that, it is recommended not to use reserved keywords as function parameter names.
This commit:
* Renames the `$echo` parameter to `$display` in:
* `wp_nonce_field()`
* `wp_referer_field()`
* `wp_original_referer_field()`
* Renames the `$string` parameter to `$input_string` in
* `_wp_json_convert_string()`
* `_wp_to_kebab_case()`
* Renames the `$list` parameter to `$input_list` in:
* `wp_parse_list()`
* `wp_parse_id_list()`
* `wp_parse_slug_list()`
* `wp_filter_object_list()`
* `wp_list_filter()`
* `wp_list_pluck()`
* `wp_list_sort()`
* Renames the `$array` parameter to `$input_array` in:
* `add_magic_quotes()`
* `wp_array_slice_assoc()`
* `_wp_array_get()`
* `_wp_array_set()`
* Renames the `$function` parameter to `$function_name` in:
* `_deprecated_function()`
* `_deprecated_argument()`
* `_doing_it_wrong()`
* Renames the `$class` parameter to `$class_name` in `_deprecated_constructor()`.
* Renames the `$default` parameter to `$default_value` in `apache_mod_loaded()`.
* Renames the `$var` parameter to `$value` in `wp_validate_boolean()`.
* Amends the `$input` parameter in `wp_parse_str()` for consistency.
Follow-up to [52946], [52996], [52997], [52998], [53003], [53014], [53029], [53039], [53116], [53117], [53137], [53174], [53184], [53185], [53192], [53193], [53198], [53203], [53207], [53215], [53216], [53220], [53230], [53232], [53236], [53239], [53240], [53242], [53243], [53245], [53246], [53257], [53269], [53270], [53271], [53272], [53273], [53274], [53275], [53276], [53277], [53281], [53283], [53284], [53285], [53287], [53364], [53365], [54927].
Props jrf, aristath, poena, justinahinon, SergeyBiryukov.
See #56788.
Built from https://develop.svn.wordpress.org/trunk@54929
git-svn-id: http://core.svn.wordpress.org/trunk@54481 1a063a9b-81f0-0310-95a4-ce76da25c4cd
2022-12-03 10:07:14 -05:00
$input_list = array_filter ( $input_list , 'is_scalar' );
2022-10-11 09:25:11 -04:00
Code Modernization: Rename parameters that use reserved keywords in `wp-includes/functions.php`.
While using reserved PHP keywords as parameter name labels is allowed, in the context of function calls using named parameters in PHP 8.0+, this will easily lead to confusion. To avoid that, it is recommended not to use reserved keywords as function parameter names.
This commit:
* Renames the `$echo` parameter to `$display` in:
* `wp_nonce_field()`
* `wp_referer_field()`
* `wp_original_referer_field()`
* Renames the `$string` parameter to `$input_string` in
* `_wp_json_convert_string()`
* `_wp_to_kebab_case()`
* Renames the `$list` parameter to `$input_list` in:
* `wp_parse_list()`
* `wp_parse_id_list()`
* `wp_parse_slug_list()`
* `wp_filter_object_list()`
* `wp_list_filter()`
* `wp_list_pluck()`
* `wp_list_sort()`
* Renames the `$array` parameter to `$input_array` in:
* `add_magic_quotes()`
* `wp_array_slice_assoc()`
* `_wp_array_get()`
* `_wp_array_set()`
* Renames the `$function` parameter to `$function_name` in:
* `_deprecated_function()`
* `_deprecated_argument()`
* `_doing_it_wrong()`
* Renames the `$class` parameter to `$class_name` in `_deprecated_constructor()`.
* Renames the `$default` parameter to `$default_value` in `apache_mod_loaded()`.
* Renames the `$var` parameter to `$value` in `wp_validate_boolean()`.
* Amends the `$input` parameter in `wp_parse_str()` for consistency.
Follow-up to [52946], [52996], [52997], [52998], [53003], [53014], [53029], [53039], [53116], [53117], [53137], [53174], [53184], [53185], [53192], [53193], [53198], [53203], [53207], [53215], [53216], [53220], [53230], [53232], [53236], [53239], [53240], [53242], [53243], [53245], [53246], [53257], [53269], [53270], [53271], [53272], [53273], [53274], [53275], [53276], [53277], [53281], [53283], [53284], [53285], [53287], [53364], [53365], [54927].
Props jrf, aristath, poena, justinahinon, SergeyBiryukov.
See #56788.
Built from https://develop.svn.wordpress.org/trunk@54929
git-svn-id: http://core.svn.wordpress.org/trunk@54481 1a063a9b-81f0-0310-95a4-ce76da25c4cd
2022-12-03 10:07:14 -05:00
return $input_list ;
2019-01-10 16:06:49 -05:00
}
2010-01-08 03:44:45 -05:00
/**
2021-01-06 12:25:07 -05:00
* Cleans up an array , comma - or space - separated list of IDs .
2010-01-08 03:44:45 -05:00
*
* @ since 3.0 . 0
2021-06-01 17:21:57 -04:00
* @ since 5.1 . 0 Refactored to use wp_parse_list () .
2010-01-08 03:44:45 -05:00
*
Code Modernization: Rename parameters that use reserved keywords in `wp-includes/functions.php`.
While using reserved PHP keywords as parameter name labels is allowed, in the context of function calls using named parameters in PHP 8.0+, this will easily lead to confusion. To avoid that, it is recommended not to use reserved keywords as function parameter names.
This commit:
* Renames the `$echo` parameter to `$display` in:
* `wp_nonce_field()`
* `wp_referer_field()`
* `wp_original_referer_field()`
* Renames the `$string` parameter to `$input_string` in
* `_wp_json_convert_string()`
* `_wp_to_kebab_case()`
* Renames the `$list` parameter to `$input_list` in:
* `wp_parse_list()`
* `wp_parse_id_list()`
* `wp_parse_slug_list()`
* `wp_filter_object_list()`
* `wp_list_filter()`
* `wp_list_pluck()`
* `wp_list_sort()`
* Renames the `$array` parameter to `$input_array` in:
* `add_magic_quotes()`
* `wp_array_slice_assoc()`
* `_wp_array_get()`
* `_wp_array_set()`
* Renames the `$function` parameter to `$function_name` in:
* `_deprecated_function()`
* `_deprecated_argument()`
* `_doing_it_wrong()`
* Renames the `$class` parameter to `$class_name` in `_deprecated_constructor()`.
* Renames the `$default` parameter to `$default_value` in `apache_mod_loaded()`.
* Renames the `$var` parameter to `$value` in `wp_validate_boolean()`.
* Amends the `$input` parameter in `wp_parse_str()` for consistency.
Follow-up to [52946], [52996], [52997], [52998], [53003], [53014], [53029], [53039], [53116], [53117], [53137], [53174], [53184], [53185], [53192], [53193], [53198], [53203], [53207], [53215], [53216], [53220], [53230], [53232], [53236], [53239], [53240], [53242], [53243], [53245], [53246], [53257], [53269], [53270], [53271], [53272], [53273], [53274], [53275], [53276], [53277], [53281], [53283], [53284], [53285], [53287], [53364], [53365], [54927].
Props jrf, aristath, poena, justinahinon, SergeyBiryukov.
See #56788.
Built from https://develop.svn.wordpress.org/trunk@54929
git-svn-id: http://core.svn.wordpress.org/trunk@54481 1a063a9b-81f0-0310-95a4-ce76da25c4cd
2022-12-03 10:07:14 -05:00
* @ param array | string $input_list List of IDs .
2019-11-05 16:23:02 -05:00
* @ return int [] Sanitized array of IDs .
2010-01-08 03:44:45 -05:00
*/
Code Modernization: Rename parameters that use reserved keywords in `wp-includes/functions.php`.
While using reserved PHP keywords as parameter name labels is allowed, in the context of function calls using named parameters in PHP 8.0+, this will easily lead to confusion. To avoid that, it is recommended not to use reserved keywords as function parameter names.
This commit:
* Renames the `$echo` parameter to `$display` in:
* `wp_nonce_field()`
* `wp_referer_field()`
* `wp_original_referer_field()`
* Renames the `$string` parameter to `$input_string` in
* `_wp_json_convert_string()`
* `_wp_to_kebab_case()`
* Renames the `$list` parameter to `$input_list` in:
* `wp_parse_list()`
* `wp_parse_id_list()`
* `wp_parse_slug_list()`
* `wp_filter_object_list()`
* `wp_list_filter()`
* `wp_list_pluck()`
* `wp_list_sort()`
* Renames the `$array` parameter to `$input_array` in:
* `add_magic_quotes()`
* `wp_array_slice_assoc()`
* `_wp_array_get()`
* `_wp_array_set()`
* Renames the `$function` parameter to `$function_name` in:
* `_deprecated_function()`
* `_deprecated_argument()`
* `_doing_it_wrong()`
* Renames the `$class` parameter to `$class_name` in `_deprecated_constructor()`.
* Renames the `$default` parameter to `$default_value` in `apache_mod_loaded()`.
* Renames the `$var` parameter to `$value` in `wp_validate_boolean()`.
* Amends the `$input` parameter in `wp_parse_str()` for consistency.
Follow-up to [52946], [52996], [52997], [52998], [53003], [53014], [53029], [53039], [53116], [53117], [53137], [53174], [53184], [53185], [53192], [53193], [53198], [53203], [53207], [53215], [53216], [53220], [53230], [53232], [53236], [53239], [53240], [53242], [53243], [53245], [53246], [53257], [53269], [53270], [53271], [53272], [53273], [53274], [53275], [53276], [53277], [53281], [53283], [53284], [53285], [53287], [53364], [53365], [54927].
Props jrf, aristath, poena, justinahinon, SergeyBiryukov.
See #56788.
Built from https://develop.svn.wordpress.org/trunk@54929
git-svn-id: http://core.svn.wordpress.org/trunk@54481 1a063a9b-81f0-0310-95a4-ce76da25c4cd
2022-12-03 10:07:14 -05:00
function wp_parse_id_list ( $input_list ) {
$input_list = wp_parse_list ( $input_list );
2010-01-08 03:44:45 -05:00
Code Modernization: Rename parameters that use reserved keywords in `wp-includes/functions.php`.
While using reserved PHP keywords as parameter name labels is allowed, in the context of function calls using named parameters in PHP 8.0+, this will easily lead to confusion. To avoid that, it is recommended not to use reserved keywords as function parameter names.
This commit:
* Renames the `$echo` parameter to `$display` in:
* `wp_nonce_field()`
* `wp_referer_field()`
* `wp_original_referer_field()`
* Renames the `$string` parameter to `$input_string` in
* `_wp_json_convert_string()`
* `_wp_to_kebab_case()`
* Renames the `$list` parameter to `$input_list` in:
* `wp_parse_list()`
* `wp_parse_id_list()`
* `wp_parse_slug_list()`
* `wp_filter_object_list()`
* `wp_list_filter()`
* `wp_list_pluck()`
* `wp_list_sort()`
* Renames the `$array` parameter to `$input_array` in:
* `add_magic_quotes()`
* `wp_array_slice_assoc()`
* `_wp_array_get()`
* `_wp_array_set()`
* Renames the `$function` parameter to `$function_name` in:
* `_deprecated_function()`
* `_deprecated_argument()`
* `_doing_it_wrong()`
* Renames the `$class` parameter to `$class_name` in `_deprecated_constructor()`.
* Renames the `$default` parameter to `$default_value` in `apache_mod_loaded()`.
* Renames the `$var` parameter to `$value` in `wp_validate_boolean()`.
* Amends the `$input` parameter in `wp_parse_str()` for consistency.
Follow-up to [52946], [52996], [52997], [52998], [53003], [53014], [53029], [53039], [53116], [53117], [53137], [53174], [53184], [53185], [53192], [53193], [53198], [53203], [53207], [53215], [53216], [53220], [53230], [53232], [53236], [53239], [53240], [53242], [53243], [53245], [53246], [53257], [53269], [53270], [53271], [53272], [53273], [53274], [53275], [53276], [53277], [53281], [53283], [53284], [53285], [53287], [53364], [53365], [54927].
Props jrf, aristath, poena, justinahinon, SergeyBiryukov.
See #56788.
Built from https://develop.svn.wordpress.org/trunk@54929
git-svn-id: http://core.svn.wordpress.org/trunk@54481 1a063a9b-81f0-0310-95a4-ce76da25c4cd
2022-12-03 10:07:14 -05:00
return array_unique ( array_map ( 'absint' , $input_list ) );
2010-01-08 03:44:45 -05:00
}
REST API: Introduce the Content API endpoints.
REST API endpoints for your WordPress content. These endpoints provide machine-readable external access to your WordPress site with a clear, standards-driven interface, allowing new and innovative apps for interacting with your site. These endpoints support all of the following:
- Posts: Read and write access to all post data, for all types of post-based data, including pages and media.
- Comments: Read and write access to all comment data. This includes pingbacks and trackbacks.
- Terms: Read and write access to all term data.
- Users: Read and write access to all user data. This includes public access to some data for post authors.
- Meta: Read and write access to metadata for posts, comments, terms, and users, on an opt-in basis from plugins.
- Settings: Read and write access to settings, on an opt-in basis from plugins and core. This enables API management of key site content values that are technically stored in options, such as site title and byline.
Love your REST API, WordPress! The infrastructure says, "Let's do lunch!" but the content API endpoints say, "You're paying!"
Props rmccue, rachelbaker, danielbachhuber, joehoyle, adamsilverstein, afurculita, ahmadawais, airesvsg, alisspers, antisilent, apokalyptik, artoliukkonen, attitude, boonebgorges, bradyvercher, brianhogg, caseypatrickdriscoll, chopinbach, chredd, christianesperar, chrisvanpatten, claudiolabarbera, claudiosmweb, cmmarslender, codebykat, coderkevin, codfish, codonnell822, daggerhart, danielpunkass, davidbhayes, delphinus, desrosj, dimadin, dotancohen, DrewAPicture, Dudo1985, duncanjbrown, eherman24, eivhyl, eliorivero, elyobo, en-alis, ericandrewlewis, ericpedia, evansobkowicz, fjarrett, frozzare, georgestephanis, greatislander, guavaworks, hideokamoto, hkdobrev, hubdotcom, hurtige, iandunn, ircrash, ironpaperweight, iseulde, Japh, jaredcobb, JDGrimes, jdolan, jdoubleu, jeremyfelt, jimt, jjeaton, jmusal, jnylen0, johanmynhardt, johnbillion, jonathanbardo, jorbin, joshkadis, JPry, jshreve, jtsternberg, JustinSainton, kacperszurek, kadamwhite, kalenjohnson, kellbot, kjbenk, kokarn, krogsgard, kuchenundkakao, kuldipem, kwight, lgedeon, lukepettway, mantismamita, markoheijnen, matrixik, mattheu, mauteri, maxcutler, mayukojpn, michael-arestad, miyauchi, mjbanks, modemlooper, mrbobbybryant, NateWr, nathanrice, netweb, NikV, nullvariable, oskosk, oso96_2000, oxymoron, pcfreak30, pento, peterwilsoncc, Pezzab, phh, pippinsplugins, pjgalbraith, pkevan, pollyplummer, pushred, quasel, QWp6t, schlessera, schrapel, Shelob9, shprink, simonlampen, Soean, solal, tapsboy, tfrommen, tharsheblows, thenbrent, tierra, tlovett1, tnegri, tobych, Toddses, toro_unit, traversal, vanillalounge, vishalkakadiya, wanecek, web2style, webbgaraget, websupporter, westonruter, whyisjake, wonderboymusic, wpsmith, xknown, zyphonic.
Fixes #38373.
Built from https://develop.svn.wordpress.org/trunk@38832
git-svn-id: http://core.svn.wordpress.org/trunk@38775 1a063a9b-81f0-0310-95a4-ce76da25c4cd
2016-10-19 22:55:32 -04:00
/**
2021-01-06 12:25:07 -05:00
* Cleans up an array , comma - or space - separated list of slugs .
REST API: Introduce the Content API endpoints.
REST API endpoints for your WordPress content. These endpoints provide machine-readable external access to your WordPress site with a clear, standards-driven interface, allowing new and innovative apps for interacting with your site. These endpoints support all of the following:
- Posts: Read and write access to all post data, for all types of post-based data, including pages and media.
- Comments: Read and write access to all comment data. This includes pingbacks and trackbacks.
- Terms: Read and write access to all term data.
- Users: Read and write access to all user data. This includes public access to some data for post authors.
- Meta: Read and write access to metadata for posts, comments, terms, and users, on an opt-in basis from plugins.
- Settings: Read and write access to settings, on an opt-in basis from plugins and core. This enables API management of key site content values that are technically stored in options, such as site title and byline.
Love your REST API, WordPress! The infrastructure says, "Let's do lunch!" but the content API endpoints say, "You're paying!"
Props rmccue, rachelbaker, danielbachhuber, joehoyle, adamsilverstein, afurculita, ahmadawais, airesvsg, alisspers, antisilent, apokalyptik, artoliukkonen, attitude, boonebgorges, bradyvercher, brianhogg, caseypatrickdriscoll, chopinbach, chredd, christianesperar, chrisvanpatten, claudiolabarbera, claudiosmweb, cmmarslender, codebykat, coderkevin, codfish, codonnell822, daggerhart, danielpunkass, davidbhayes, delphinus, desrosj, dimadin, dotancohen, DrewAPicture, Dudo1985, duncanjbrown, eherman24, eivhyl, eliorivero, elyobo, en-alis, ericandrewlewis, ericpedia, evansobkowicz, fjarrett, frozzare, georgestephanis, greatislander, guavaworks, hideokamoto, hkdobrev, hubdotcom, hurtige, iandunn, ircrash, ironpaperweight, iseulde, Japh, jaredcobb, JDGrimes, jdolan, jdoubleu, jeremyfelt, jimt, jjeaton, jmusal, jnylen0, johanmynhardt, johnbillion, jonathanbardo, jorbin, joshkadis, JPry, jshreve, jtsternberg, JustinSainton, kacperszurek, kadamwhite, kalenjohnson, kellbot, kjbenk, kokarn, krogsgard, kuchenundkakao, kuldipem, kwight, lgedeon, lukepettway, mantismamita, markoheijnen, matrixik, mattheu, mauteri, maxcutler, mayukojpn, michael-arestad, miyauchi, mjbanks, modemlooper, mrbobbybryant, NateWr, nathanrice, netweb, NikV, nullvariable, oskosk, oso96_2000, oxymoron, pcfreak30, pento, peterwilsoncc, Pezzab, phh, pippinsplugins, pjgalbraith, pkevan, pollyplummer, pushred, quasel, QWp6t, schlessera, schrapel, Shelob9, shprink, simonlampen, Soean, solal, tapsboy, tfrommen, tharsheblows, thenbrent, tierra, tlovett1, tnegri, tobych, Toddses, toro_unit, traversal, vanillalounge, vishalkakadiya, wanecek, web2style, webbgaraget, websupporter, westonruter, whyisjake, wonderboymusic, wpsmith, xknown, zyphonic.
Fixes #38373.
Built from https://develop.svn.wordpress.org/trunk@38832
git-svn-id: http://core.svn.wordpress.org/trunk@38775 1a063a9b-81f0-0310-95a4-ce76da25c4cd
2016-10-19 22:55:32 -04:00
*
* @ since 4.7 . 0
2021-06-01 17:21:57 -04:00
* @ since 5.1 . 0 Refactored to use wp_parse_list () .
REST API: Introduce the Content API endpoints.
REST API endpoints for your WordPress content. These endpoints provide machine-readable external access to your WordPress site with a clear, standards-driven interface, allowing new and innovative apps for interacting with your site. These endpoints support all of the following:
- Posts: Read and write access to all post data, for all types of post-based data, including pages and media.
- Comments: Read and write access to all comment data. This includes pingbacks and trackbacks.
- Terms: Read and write access to all term data.
- Users: Read and write access to all user data. This includes public access to some data for post authors.
- Meta: Read and write access to metadata for posts, comments, terms, and users, on an opt-in basis from plugins.
- Settings: Read and write access to settings, on an opt-in basis from plugins and core. This enables API management of key site content values that are technically stored in options, such as site title and byline.
Love your REST API, WordPress! The infrastructure says, "Let's do lunch!" but the content API endpoints say, "You're paying!"
Props rmccue, rachelbaker, danielbachhuber, joehoyle, adamsilverstein, afurculita, ahmadawais, airesvsg, alisspers, antisilent, apokalyptik, artoliukkonen, attitude, boonebgorges, bradyvercher, brianhogg, caseypatrickdriscoll, chopinbach, chredd, christianesperar, chrisvanpatten, claudiolabarbera, claudiosmweb, cmmarslender, codebykat, coderkevin, codfish, codonnell822, daggerhart, danielpunkass, davidbhayes, delphinus, desrosj, dimadin, dotancohen, DrewAPicture, Dudo1985, duncanjbrown, eherman24, eivhyl, eliorivero, elyobo, en-alis, ericandrewlewis, ericpedia, evansobkowicz, fjarrett, frozzare, georgestephanis, greatislander, guavaworks, hideokamoto, hkdobrev, hubdotcom, hurtige, iandunn, ircrash, ironpaperweight, iseulde, Japh, jaredcobb, JDGrimes, jdolan, jdoubleu, jeremyfelt, jimt, jjeaton, jmusal, jnylen0, johanmynhardt, johnbillion, jonathanbardo, jorbin, joshkadis, JPry, jshreve, jtsternberg, JustinSainton, kacperszurek, kadamwhite, kalenjohnson, kellbot, kjbenk, kokarn, krogsgard, kuchenundkakao, kuldipem, kwight, lgedeon, lukepettway, mantismamita, markoheijnen, matrixik, mattheu, mauteri, maxcutler, mayukojpn, michael-arestad, miyauchi, mjbanks, modemlooper, mrbobbybryant, NateWr, nathanrice, netweb, NikV, nullvariable, oskosk, oso96_2000, oxymoron, pcfreak30, pento, peterwilsoncc, Pezzab, phh, pippinsplugins, pjgalbraith, pkevan, pollyplummer, pushred, quasel, QWp6t, schlessera, schrapel, Shelob9, shprink, simonlampen, Soean, solal, tapsboy, tfrommen, tharsheblows, thenbrent, tierra, tlovett1, tnegri, tobych, Toddses, toro_unit, traversal, vanillalounge, vishalkakadiya, wanecek, web2style, webbgaraget, websupporter, westonruter, whyisjake, wonderboymusic, wpsmith, xknown, zyphonic.
Fixes #38373.
Built from https://develop.svn.wordpress.org/trunk@38832
git-svn-id: http://core.svn.wordpress.org/trunk@38775 1a063a9b-81f0-0310-95a4-ce76da25c4cd
2016-10-19 22:55:32 -04:00
*
Code Modernization: Rename parameters that use reserved keywords in `wp-includes/functions.php`.
While using reserved PHP keywords as parameter name labels is allowed, in the context of function calls using named parameters in PHP 8.0+, this will easily lead to confusion. To avoid that, it is recommended not to use reserved keywords as function parameter names.
This commit:
* Renames the `$echo` parameter to `$display` in:
* `wp_nonce_field()`
* `wp_referer_field()`
* `wp_original_referer_field()`
* Renames the `$string` parameter to `$input_string` in
* `_wp_json_convert_string()`
* `_wp_to_kebab_case()`
* Renames the `$list` parameter to `$input_list` in:
* `wp_parse_list()`
* `wp_parse_id_list()`
* `wp_parse_slug_list()`
* `wp_filter_object_list()`
* `wp_list_filter()`
* `wp_list_pluck()`
* `wp_list_sort()`
* Renames the `$array` parameter to `$input_array` in:
* `add_magic_quotes()`
* `wp_array_slice_assoc()`
* `_wp_array_get()`
* `_wp_array_set()`
* Renames the `$function` parameter to `$function_name` in:
* `_deprecated_function()`
* `_deprecated_argument()`
* `_doing_it_wrong()`
* Renames the `$class` parameter to `$class_name` in `_deprecated_constructor()`.
* Renames the `$default` parameter to `$default_value` in `apache_mod_loaded()`.
* Renames the `$var` parameter to `$value` in `wp_validate_boolean()`.
* Amends the `$input` parameter in `wp_parse_str()` for consistency.
Follow-up to [52946], [52996], [52997], [52998], [53003], [53014], [53029], [53039], [53116], [53117], [53137], [53174], [53184], [53185], [53192], [53193], [53198], [53203], [53207], [53215], [53216], [53220], [53230], [53232], [53236], [53239], [53240], [53242], [53243], [53245], [53246], [53257], [53269], [53270], [53271], [53272], [53273], [53274], [53275], [53276], [53277], [53281], [53283], [53284], [53285], [53287], [53364], [53365], [54927].
Props jrf, aristath, poena, justinahinon, SergeyBiryukov.
See #56788.
Built from https://develop.svn.wordpress.org/trunk@54929
git-svn-id: http://core.svn.wordpress.org/trunk@54481 1a063a9b-81f0-0310-95a4-ce76da25c4cd
2022-12-03 10:07:14 -05:00
* @ param array | string $input_list List of slugs .
2019-11-05 16:23:02 -05:00
* @ return string [] Sanitized array of slugs .
REST API: Introduce the Content API endpoints.
REST API endpoints for your WordPress content. These endpoints provide machine-readable external access to your WordPress site with a clear, standards-driven interface, allowing new and innovative apps for interacting with your site. These endpoints support all of the following:
- Posts: Read and write access to all post data, for all types of post-based data, including pages and media.
- Comments: Read and write access to all comment data. This includes pingbacks and trackbacks.
- Terms: Read and write access to all term data.
- Users: Read and write access to all user data. This includes public access to some data for post authors.
- Meta: Read and write access to metadata for posts, comments, terms, and users, on an opt-in basis from plugins.
- Settings: Read and write access to settings, on an opt-in basis from plugins and core. This enables API management of key site content values that are technically stored in options, such as site title and byline.
Love your REST API, WordPress! The infrastructure says, "Let's do lunch!" but the content API endpoints say, "You're paying!"
Props rmccue, rachelbaker, danielbachhuber, joehoyle, adamsilverstein, afurculita, ahmadawais, airesvsg, alisspers, antisilent, apokalyptik, artoliukkonen, attitude, boonebgorges, bradyvercher, brianhogg, caseypatrickdriscoll, chopinbach, chredd, christianesperar, chrisvanpatten, claudiolabarbera, claudiosmweb, cmmarslender, codebykat, coderkevin, codfish, codonnell822, daggerhart, danielpunkass, davidbhayes, delphinus, desrosj, dimadin, dotancohen, DrewAPicture, Dudo1985, duncanjbrown, eherman24, eivhyl, eliorivero, elyobo, en-alis, ericandrewlewis, ericpedia, evansobkowicz, fjarrett, frozzare, georgestephanis, greatislander, guavaworks, hideokamoto, hkdobrev, hubdotcom, hurtige, iandunn, ircrash, ironpaperweight, iseulde, Japh, jaredcobb, JDGrimes, jdolan, jdoubleu, jeremyfelt, jimt, jjeaton, jmusal, jnylen0, johanmynhardt, johnbillion, jonathanbardo, jorbin, joshkadis, JPry, jshreve, jtsternberg, JustinSainton, kacperszurek, kadamwhite, kalenjohnson, kellbot, kjbenk, kokarn, krogsgard, kuchenundkakao, kuldipem, kwight, lgedeon, lukepettway, mantismamita, markoheijnen, matrixik, mattheu, mauteri, maxcutler, mayukojpn, michael-arestad, miyauchi, mjbanks, modemlooper, mrbobbybryant, NateWr, nathanrice, netweb, NikV, nullvariable, oskosk, oso96_2000, oxymoron, pcfreak30, pento, peterwilsoncc, Pezzab, phh, pippinsplugins, pjgalbraith, pkevan, pollyplummer, pushred, quasel, QWp6t, schlessera, schrapel, Shelob9, shprink, simonlampen, Soean, solal, tapsboy, tfrommen, tharsheblows, thenbrent, tierra, tlovett1, tnegri, tobych, Toddses, toro_unit, traversal, vanillalounge, vishalkakadiya, wanecek, web2style, webbgaraget, websupporter, westonruter, whyisjake, wonderboymusic, wpsmith, xknown, zyphonic.
Fixes #38373.
Built from https://develop.svn.wordpress.org/trunk@38832
git-svn-id: http://core.svn.wordpress.org/trunk@38775 1a063a9b-81f0-0310-95a4-ce76da25c4cd
2016-10-19 22:55:32 -04:00
*/
Code Modernization: Rename parameters that use reserved keywords in `wp-includes/functions.php`.
While using reserved PHP keywords as parameter name labels is allowed, in the context of function calls using named parameters in PHP 8.0+, this will easily lead to confusion. To avoid that, it is recommended not to use reserved keywords as function parameter names.
This commit:
* Renames the `$echo` parameter to `$display` in:
* `wp_nonce_field()`
* `wp_referer_field()`
* `wp_original_referer_field()`
* Renames the `$string` parameter to `$input_string` in
* `_wp_json_convert_string()`
* `_wp_to_kebab_case()`
* Renames the `$list` parameter to `$input_list` in:
* `wp_parse_list()`
* `wp_parse_id_list()`
* `wp_parse_slug_list()`
* `wp_filter_object_list()`
* `wp_list_filter()`
* `wp_list_pluck()`
* `wp_list_sort()`
* Renames the `$array` parameter to `$input_array` in:
* `add_magic_quotes()`
* `wp_array_slice_assoc()`
* `_wp_array_get()`
* `_wp_array_set()`
* Renames the `$function` parameter to `$function_name` in:
* `_deprecated_function()`
* `_deprecated_argument()`
* `_doing_it_wrong()`
* Renames the `$class` parameter to `$class_name` in `_deprecated_constructor()`.
* Renames the `$default` parameter to `$default_value` in `apache_mod_loaded()`.
* Renames the `$var` parameter to `$value` in `wp_validate_boolean()`.
* Amends the `$input` parameter in `wp_parse_str()` for consistency.
Follow-up to [52946], [52996], [52997], [52998], [53003], [53014], [53029], [53039], [53116], [53117], [53137], [53174], [53184], [53185], [53192], [53193], [53198], [53203], [53207], [53215], [53216], [53220], [53230], [53232], [53236], [53239], [53240], [53242], [53243], [53245], [53246], [53257], [53269], [53270], [53271], [53272], [53273], [53274], [53275], [53276], [53277], [53281], [53283], [53284], [53285], [53287], [53364], [53365], [54927].
Props jrf, aristath, poena, justinahinon, SergeyBiryukov.
See #56788.
Built from https://develop.svn.wordpress.org/trunk@54929
git-svn-id: http://core.svn.wordpress.org/trunk@54481 1a063a9b-81f0-0310-95a4-ce76da25c4cd
2022-12-03 10:07:14 -05:00
function wp_parse_slug_list ( $input_list ) {
$input_list = wp_parse_list ( $input_list );
REST API: Introduce the Content API endpoints.
REST API endpoints for your WordPress content. These endpoints provide machine-readable external access to your WordPress site with a clear, standards-driven interface, allowing new and innovative apps for interacting with your site. These endpoints support all of the following:
- Posts: Read and write access to all post data, for all types of post-based data, including pages and media.
- Comments: Read and write access to all comment data. This includes pingbacks and trackbacks.
- Terms: Read and write access to all term data.
- Users: Read and write access to all user data. This includes public access to some data for post authors.
- Meta: Read and write access to metadata for posts, comments, terms, and users, on an opt-in basis from plugins.
- Settings: Read and write access to settings, on an opt-in basis from plugins and core. This enables API management of key site content values that are technically stored in options, such as site title and byline.
Love your REST API, WordPress! The infrastructure says, "Let's do lunch!" but the content API endpoints say, "You're paying!"
Props rmccue, rachelbaker, danielbachhuber, joehoyle, adamsilverstein, afurculita, ahmadawais, airesvsg, alisspers, antisilent, apokalyptik, artoliukkonen, attitude, boonebgorges, bradyvercher, brianhogg, caseypatrickdriscoll, chopinbach, chredd, christianesperar, chrisvanpatten, claudiolabarbera, claudiosmweb, cmmarslender, codebykat, coderkevin, codfish, codonnell822, daggerhart, danielpunkass, davidbhayes, delphinus, desrosj, dimadin, dotancohen, DrewAPicture, Dudo1985, duncanjbrown, eherman24, eivhyl, eliorivero, elyobo, en-alis, ericandrewlewis, ericpedia, evansobkowicz, fjarrett, frozzare, georgestephanis, greatislander, guavaworks, hideokamoto, hkdobrev, hubdotcom, hurtige, iandunn, ircrash, ironpaperweight, iseulde, Japh, jaredcobb, JDGrimes, jdolan, jdoubleu, jeremyfelt, jimt, jjeaton, jmusal, jnylen0, johanmynhardt, johnbillion, jonathanbardo, jorbin, joshkadis, JPry, jshreve, jtsternberg, JustinSainton, kacperszurek, kadamwhite, kalenjohnson, kellbot, kjbenk, kokarn, krogsgard, kuchenundkakao, kuldipem, kwight, lgedeon, lukepettway, mantismamita, markoheijnen, matrixik, mattheu, mauteri, maxcutler, mayukojpn, michael-arestad, miyauchi, mjbanks, modemlooper, mrbobbybryant, NateWr, nathanrice, netweb, NikV, nullvariable, oskosk, oso96_2000, oxymoron, pcfreak30, pento, peterwilsoncc, Pezzab, phh, pippinsplugins, pjgalbraith, pkevan, pollyplummer, pushred, quasel, QWp6t, schlessera, schrapel, Shelob9, shprink, simonlampen, Soean, solal, tapsboy, tfrommen, tharsheblows, thenbrent, tierra, tlovett1, tnegri, tobych, Toddses, toro_unit, traversal, vanillalounge, vishalkakadiya, wanecek, web2style, webbgaraget, websupporter, westonruter, whyisjake, wonderboymusic, wpsmith, xknown, zyphonic.
Fixes #38373.
Built from https://develop.svn.wordpress.org/trunk@38832
git-svn-id: http://core.svn.wordpress.org/trunk@38775 1a063a9b-81f0-0310-95a4-ce76da25c4cd
2016-10-19 22:55:32 -04:00
Code Modernization: Rename parameters that use reserved keywords in `wp-includes/functions.php`.
While using reserved PHP keywords as parameter name labels is allowed, in the context of function calls using named parameters in PHP 8.0+, this will easily lead to confusion. To avoid that, it is recommended not to use reserved keywords as function parameter names.
This commit:
* Renames the `$echo` parameter to `$display` in:
* `wp_nonce_field()`
* `wp_referer_field()`
* `wp_original_referer_field()`
* Renames the `$string` parameter to `$input_string` in
* `_wp_json_convert_string()`
* `_wp_to_kebab_case()`
* Renames the `$list` parameter to `$input_list` in:
* `wp_parse_list()`
* `wp_parse_id_list()`
* `wp_parse_slug_list()`
* `wp_filter_object_list()`
* `wp_list_filter()`
* `wp_list_pluck()`
* `wp_list_sort()`
* Renames the `$array` parameter to `$input_array` in:
* `add_magic_quotes()`
* `wp_array_slice_assoc()`
* `_wp_array_get()`
* `_wp_array_set()`
* Renames the `$function` parameter to `$function_name` in:
* `_deprecated_function()`
* `_deprecated_argument()`
* `_doing_it_wrong()`
* Renames the `$class` parameter to `$class_name` in `_deprecated_constructor()`.
* Renames the `$default` parameter to `$default_value` in `apache_mod_loaded()`.
* Renames the `$var` parameter to `$value` in `wp_validate_boolean()`.
* Amends the `$input` parameter in `wp_parse_str()` for consistency.
Follow-up to [52946], [52996], [52997], [52998], [53003], [53014], [53029], [53039], [53116], [53117], [53137], [53174], [53184], [53185], [53192], [53193], [53198], [53203], [53207], [53215], [53216], [53220], [53230], [53232], [53236], [53239], [53240], [53242], [53243], [53245], [53246], [53257], [53269], [53270], [53271], [53272], [53273], [53274], [53275], [53276], [53277], [53281], [53283], [53284], [53285], [53287], [53364], [53365], [54927].
Props jrf, aristath, poena, justinahinon, SergeyBiryukov.
See #56788.
Built from https://develop.svn.wordpress.org/trunk@54929
git-svn-id: http://core.svn.wordpress.org/trunk@54481 1a063a9b-81f0-0310-95a4-ce76da25c4cd
2022-12-03 10:07:14 -05:00
return array_unique ( array_map ( 'sanitize_title' , $input_list ) );
REST API: Introduce the Content API endpoints.
REST API endpoints for your WordPress content. These endpoints provide machine-readable external access to your WordPress site with a clear, standards-driven interface, allowing new and innovative apps for interacting with your site. These endpoints support all of the following:
- Posts: Read and write access to all post data, for all types of post-based data, including pages and media.
- Comments: Read and write access to all comment data. This includes pingbacks and trackbacks.
- Terms: Read and write access to all term data.
- Users: Read and write access to all user data. This includes public access to some data for post authors.
- Meta: Read and write access to metadata for posts, comments, terms, and users, on an opt-in basis from plugins.
- Settings: Read and write access to settings, on an opt-in basis from plugins and core. This enables API management of key site content values that are technically stored in options, such as site title and byline.
Love your REST API, WordPress! The infrastructure says, "Let's do lunch!" but the content API endpoints say, "You're paying!"
Props rmccue, rachelbaker, danielbachhuber, joehoyle, adamsilverstein, afurculita, ahmadawais, airesvsg, alisspers, antisilent, apokalyptik, artoliukkonen, attitude, boonebgorges, bradyvercher, brianhogg, caseypatrickdriscoll, chopinbach, chredd, christianesperar, chrisvanpatten, claudiolabarbera, claudiosmweb, cmmarslender, codebykat, coderkevin, codfish, codonnell822, daggerhart, danielpunkass, davidbhayes, delphinus, desrosj, dimadin, dotancohen, DrewAPicture, Dudo1985, duncanjbrown, eherman24, eivhyl, eliorivero, elyobo, en-alis, ericandrewlewis, ericpedia, evansobkowicz, fjarrett, frozzare, georgestephanis, greatislander, guavaworks, hideokamoto, hkdobrev, hubdotcom, hurtige, iandunn, ircrash, ironpaperweight, iseulde, Japh, jaredcobb, JDGrimes, jdolan, jdoubleu, jeremyfelt, jimt, jjeaton, jmusal, jnylen0, johanmynhardt, johnbillion, jonathanbardo, jorbin, joshkadis, JPry, jshreve, jtsternberg, JustinSainton, kacperszurek, kadamwhite, kalenjohnson, kellbot, kjbenk, kokarn, krogsgard, kuchenundkakao, kuldipem, kwight, lgedeon, lukepettway, mantismamita, markoheijnen, matrixik, mattheu, mauteri, maxcutler, mayukojpn, michael-arestad, miyauchi, mjbanks, modemlooper, mrbobbybryant, NateWr, nathanrice, netweb, NikV, nullvariable, oskosk, oso96_2000, oxymoron, pcfreak30, pento, peterwilsoncc, Pezzab, phh, pippinsplugins, pjgalbraith, pkevan, pollyplummer, pushred, quasel, QWp6t, schlessera, schrapel, Shelob9, shprink, simonlampen, Soean, solal, tapsboy, tfrommen, tharsheblows, thenbrent, tierra, tlovett1, tnegri, tobych, Toddses, toro_unit, traversal, vanillalounge, vishalkakadiya, wanecek, web2style, webbgaraget, websupporter, westonruter, whyisjake, wonderboymusic, wpsmith, xknown, zyphonic.
Fixes #38373.
Built from https://develop.svn.wordpress.org/trunk@38832
git-svn-id: http://core.svn.wordpress.org/trunk@38775 1a063a9b-81f0-0310-95a4-ce76da25c4cd
2016-10-19 22:55:32 -04:00
}
2010-09-05 14:47:25 -04:00
/**
2022-08-12 05:53:11 -04:00
* Extracts a slice of an array , given a list of keys .
2010-09-05 14:47:25 -04:00
*
* @ since 3.1 . 0
*
Code Modernization: Rename parameters that use reserved keywords in `wp-includes/functions.php`.
While using reserved PHP keywords as parameter name labels is allowed, in the context of function calls using named parameters in PHP 8.0+, this will easily lead to confusion. To avoid that, it is recommended not to use reserved keywords as function parameter names.
This commit:
* Renames the `$echo` parameter to `$display` in:
* `wp_nonce_field()`
* `wp_referer_field()`
* `wp_original_referer_field()`
* Renames the `$string` parameter to `$input_string` in
* `_wp_json_convert_string()`
* `_wp_to_kebab_case()`
* Renames the `$list` parameter to `$input_list` in:
* `wp_parse_list()`
* `wp_parse_id_list()`
* `wp_parse_slug_list()`
* `wp_filter_object_list()`
* `wp_list_filter()`
* `wp_list_pluck()`
* `wp_list_sort()`
* Renames the `$array` parameter to `$input_array` in:
* `add_magic_quotes()`
* `wp_array_slice_assoc()`
* `_wp_array_get()`
* `_wp_array_set()`
* Renames the `$function` parameter to `$function_name` in:
* `_deprecated_function()`
* `_deprecated_argument()`
* `_doing_it_wrong()`
* Renames the `$class` parameter to `$class_name` in `_deprecated_constructor()`.
* Renames the `$default` parameter to `$default_value` in `apache_mod_loaded()`.
* Renames the `$var` parameter to `$value` in `wp_validate_boolean()`.
* Amends the `$input` parameter in `wp_parse_str()` for consistency.
Follow-up to [52946], [52996], [52997], [52998], [53003], [53014], [53029], [53039], [53116], [53117], [53137], [53174], [53184], [53185], [53192], [53193], [53198], [53203], [53207], [53215], [53216], [53220], [53230], [53232], [53236], [53239], [53240], [53242], [53243], [53245], [53246], [53257], [53269], [53270], [53271], [53272], [53273], [53274], [53275], [53276], [53277], [53281], [53283], [53284], [53285], [53287], [53364], [53365], [54927].
Props jrf, aristath, poena, justinahinon, SergeyBiryukov.
See #56788.
Built from https://develop.svn.wordpress.org/trunk@54929
git-svn-id: http://core.svn.wordpress.org/trunk@54481 1a063a9b-81f0-0310-95a4-ce76da25c4cd
2022-12-03 10:07:14 -05:00
* @ param array $input_array The original array .
* @ param array $keys The list of keys .
2014-06-30 21:44:15 -04:00
* @ return array The array slice .
2010-09-05 14:47:25 -04:00
*/
Code Modernization: Rename parameters that use reserved keywords in `wp-includes/functions.php`.
While using reserved PHP keywords as parameter name labels is allowed, in the context of function calls using named parameters in PHP 8.0+, this will easily lead to confusion. To avoid that, it is recommended not to use reserved keywords as function parameter names.
This commit:
* Renames the `$echo` parameter to `$display` in:
* `wp_nonce_field()`
* `wp_referer_field()`
* `wp_original_referer_field()`
* Renames the `$string` parameter to `$input_string` in
* `_wp_json_convert_string()`
* `_wp_to_kebab_case()`
* Renames the `$list` parameter to `$input_list` in:
* `wp_parse_list()`
* `wp_parse_id_list()`
* `wp_parse_slug_list()`
* `wp_filter_object_list()`
* `wp_list_filter()`
* `wp_list_pluck()`
* `wp_list_sort()`
* Renames the `$array` parameter to `$input_array` in:
* `add_magic_quotes()`
* `wp_array_slice_assoc()`
* `_wp_array_get()`
* `_wp_array_set()`
* Renames the `$function` parameter to `$function_name` in:
* `_deprecated_function()`
* `_deprecated_argument()`
* `_doing_it_wrong()`
* Renames the `$class` parameter to `$class_name` in `_deprecated_constructor()`.
* Renames the `$default` parameter to `$default_value` in `apache_mod_loaded()`.
* Renames the `$var` parameter to `$value` in `wp_validate_boolean()`.
* Amends the `$input` parameter in `wp_parse_str()` for consistency.
Follow-up to [52946], [52996], [52997], [52998], [53003], [53014], [53029], [53039], [53116], [53117], [53137], [53174], [53184], [53185], [53192], [53193], [53198], [53203], [53207], [53215], [53216], [53220], [53230], [53232], [53236], [53239], [53240], [53242], [53243], [53245], [53246], [53257], [53269], [53270], [53271], [53272], [53273], [53274], [53275], [53276], [53277], [53281], [53283], [53284], [53285], [53287], [53364], [53365], [54927].
Props jrf, aristath, poena, justinahinon, SergeyBiryukov.
See #56788.
Built from https://develop.svn.wordpress.org/trunk@54929
git-svn-id: http://core.svn.wordpress.org/trunk@54481 1a063a9b-81f0-0310-95a4-ce76da25c4cd
2022-12-03 10:07:14 -05:00
function wp_array_slice_assoc ( $input_array , $keys ) {
2010-09-05 14:47:25 -04:00
$slice = array ();
2020-10-13 22:16:08 -04:00
2017-11-30 18:11:00 -05:00
foreach ( $keys as $key ) {
Code Modernization: Rename parameters that use reserved keywords in `wp-includes/functions.php`.
While using reserved PHP keywords as parameter name labels is allowed, in the context of function calls using named parameters in PHP 8.0+, this will easily lead to confusion. To avoid that, it is recommended not to use reserved keywords as function parameter names.
This commit:
* Renames the `$echo` parameter to `$display` in:
* `wp_nonce_field()`
* `wp_referer_field()`
* `wp_original_referer_field()`
* Renames the `$string` parameter to `$input_string` in
* `_wp_json_convert_string()`
* `_wp_to_kebab_case()`
* Renames the `$list` parameter to `$input_list` in:
* `wp_parse_list()`
* `wp_parse_id_list()`
* `wp_parse_slug_list()`
* `wp_filter_object_list()`
* `wp_list_filter()`
* `wp_list_pluck()`
* `wp_list_sort()`
* Renames the `$array` parameter to `$input_array` in:
* `add_magic_quotes()`
* `wp_array_slice_assoc()`
* `_wp_array_get()`
* `_wp_array_set()`
* Renames the `$function` parameter to `$function_name` in:
* `_deprecated_function()`
* `_deprecated_argument()`
* `_doing_it_wrong()`
* Renames the `$class` parameter to `$class_name` in `_deprecated_constructor()`.
* Renames the `$default` parameter to `$default_value` in `apache_mod_loaded()`.
* Renames the `$var` parameter to `$value` in `wp_validate_boolean()`.
* Amends the `$input` parameter in `wp_parse_str()` for consistency.
Follow-up to [52946], [52996], [52997], [52998], [53003], [53014], [53029], [53039], [53116], [53117], [53137], [53174], [53184], [53185], [53192], [53193], [53198], [53203], [53207], [53215], [53216], [53220], [53230], [53232], [53236], [53239], [53240], [53242], [53243], [53245], [53246], [53257], [53269], [53270], [53271], [53272], [53273], [53274], [53275], [53276], [53277], [53281], [53283], [53284], [53285], [53287], [53364], [53365], [54927].
Props jrf, aristath, poena, justinahinon, SergeyBiryukov.
See #56788.
Built from https://develop.svn.wordpress.org/trunk@54929
git-svn-id: http://core.svn.wordpress.org/trunk@54481 1a063a9b-81f0-0310-95a4-ce76da25c4cd
2022-12-03 10:07:14 -05:00
if ( isset ( $input_array [ $key ] ) ) {
$slice [ $key ] = $input_array [ $key ];
2017-11-30 18:11:00 -05:00
}
}
2010-09-05 14:47:25 -04:00
return $slice ;
}
2023-01-23 10:54:10 -05:00
/**
* Sorts the keys of an array alphabetically .
*
* The array is passed by reference so it doesn ' t get returned
* which mimics the behavior of `ksort()` .
*
* @ since 6.0 . 0
*
* @ param array $input_array The array to sort , passed by reference .
*/
function wp_recursive_ksort ( & $input_array ) {
foreach ( $input_array as & $value ) {
if ( is_array ( $value ) ) {
wp_recursive_ksort ( $value );
}
}
ksort ( $input_array );
}
2020-10-13 22:10:04 -04:00
/**
* Accesses an array in depth based on a path of keys .
*
2020-11-12 15:20:12 -05:00
* It is the PHP equivalent of JavaScript ' s `lodash.get()` and mirroring it may help other components
2020-10-13 22:10:04 -04:00
* retain some symmetry between client and server implementations .
*
2020-11-12 15:20:12 -05:00
* Example usage :
*
Code Modernization: Rename parameters that use reserved keywords in `wp-includes/functions.php`.
While using reserved PHP keywords as parameter name labels is allowed, in the context of function calls using named parameters in PHP 8.0+, this will easily lead to confusion. To avoid that, it is recommended not to use reserved keywords as function parameter names.
This commit:
* Renames the `$echo` parameter to `$display` in:
* `wp_nonce_field()`
* `wp_referer_field()`
* `wp_original_referer_field()`
* Renames the `$string` parameter to `$input_string` in
* `_wp_json_convert_string()`
* `_wp_to_kebab_case()`
* Renames the `$list` parameter to `$input_list` in:
* `wp_parse_list()`
* `wp_parse_id_list()`
* `wp_parse_slug_list()`
* `wp_filter_object_list()`
* `wp_list_filter()`
* `wp_list_pluck()`
* `wp_list_sort()`
* Renames the `$array` parameter to `$input_array` in:
* `add_magic_quotes()`
* `wp_array_slice_assoc()`
* `_wp_array_get()`
* `_wp_array_set()`
* Renames the `$function` parameter to `$function_name` in:
* `_deprecated_function()`
* `_deprecated_argument()`
* `_doing_it_wrong()`
* Renames the `$class` parameter to `$class_name` in `_deprecated_constructor()`.
* Renames the `$default` parameter to `$default_value` in `apache_mod_loaded()`.
* Renames the `$var` parameter to `$value` in `wp_validate_boolean()`.
* Amends the `$input` parameter in `wp_parse_str()` for consistency.
Follow-up to [52946], [52996], [52997], [52998], [53003], [53014], [53029], [53039], [53116], [53117], [53137], [53174], [53184], [53185], [53192], [53193], [53198], [53203], [53207], [53215], [53216], [53220], [53230], [53232], [53236], [53239], [53240], [53242], [53243], [53245], [53246], [53257], [53269], [53270], [53271], [53272], [53273], [53274], [53275], [53276], [53277], [53281], [53283], [53284], [53285], [53287], [53364], [53365], [54927].
Props jrf, aristath, poena, justinahinon, SergeyBiryukov.
See #56788.
Built from https://develop.svn.wordpress.org/trunk@54929
git-svn-id: http://core.svn.wordpress.org/trunk@54481 1a063a9b-81f0-0310-95a4-ce76da25c4cd
2022-12-03 10:07:14 -05:00
* $input_array = array (
2020-11-12 15:20:12 -05:00
* 'a' => array (
* 'b' => array (
* 'c' => 1 ,
* ),
* ),
* );
Code Modernization: Rename parameters that use reserved keywords in `wp-includes/functions.php`.
While using reserved PHP keywords as parameter name labels is allowed, in the context of function calls using named parameters in PHP 8.0+, this will easily lead to confusion. To avoid that, it is recommended not to use reserved keywords as function parameter names.
This commit:
* Renames the `$echo` parameter to `$display` in:
* `wp_nonce_field()`
* `wp_referer_field()`
* `wp_original_referer_field()`
* Renames the `$string` parameter to `$input_string` in
* `_wp_json_convert_string()`
* `_wp_to_kebab_case()`
* Renames the `$list` parameter to `$input_list` in:
* `wp_parse_list()`
* `wp_parse_id_list()`
* `wp_parse_slug_list()`
* `wp_filter_object_list()`
* `wp_list_filter()`
* `wp_list_pluck()`
* `wp_list_sort()`
* Renames the `$array` parameter to `$input_array` in:
* `add_magic_quotes()`
* `wp_array_slice_assoc()`
* `_wp_array_get()`
* `_wp_array_set()`
* Renames the `$function` parameter to `$function_name` in:
* `_deprecated_function()`
* `_deprecated_argument()`
* `_doing_it_wrong()`
* Renames the `$class` parameter to `$class_name` in `_deprecated_constructor()`.
* Renames the `$default` parameter to `$default_value` in `apache_mod_loaded()`.
* Renames the `$var` parameter to `$value` in `wp_validate_boolean()`.
* Amends the `$input` parameter in `wp_parse_str()` for consistency.
Follow-up to [52946], [52996], [52997], [52998], [53003], [53014], [53029], [53039], [53116], [53117], [53137], [53174], [53184], [53185], [53192], [53193], [53198], [53203], [53207], [53215], [53216], [53220], [53230], [53232], [53236], [53239], [53240], [53242], [53243], [53245], [53246], [53257], [53269], [53270], [53271], [53272], [53273], [53274], [53275], [53276], [53277], [53281], [53283], [53284], [53285], [53287], [53364], [53365], [54927].
Props jrf, aristath, poena, justinahinon, SergeyBiryukov.
See #56788.
Built from https://develop.svn.wordpress.org/trunk@54929
git-svn-id: http://core.svn.wordpress.org/trunk@54481 1a063a9b-81f0-0310-95a4-ce76da25c4cd
2022-12-03 10:07:14 -05:00
* _wp_array_get ( $input_array , array ( 'a' , 'b' , 'c' ) );
2020-11-12 15:20:12 -05:00
*
* @ internal
*
2020-10-13 22:10:04 -04:00
* @ since 5.6 . 0
2020-11-12 15:20:12 -05:00
* @ access private
2020-10-13 22:10:04 -04:00
*
Code Modernization: Rename parameters that use reserved keywords in `wp-includes/functions.php`.
While using reserved PHP keywords as parameter name labels is allowed, in the context of function calls using named parameters in PHP 8.0+, this will easily lead to confusion. To avoid that, it is recommended not to use reserved keywords as function parameter names.
This commit:
* Renames the `$echo` parameter to `$display` in:
* `wp_nonce_field()`
* `wp_referer_field()`
* `wp_original_referer_field()`
* Renames the `$string` parameter to `$input_string` in
* `_wp_json_convert_string()`
* `_wp_to_kebab_case()`
* Renames the `$list` parameter to `$input_list` in:
* `wp_parse_list()`
* `wp_parse_id_list()`
* `wp_parse_slug_list()`
* `wp_filter_object_list()`
* `wp_list_filter()`
* `wp_list_pluck()`
* `wp_list_sort()`
* Renames the `$array` parameter to `$input_array` in:
* `add_magic_quotes()`
* `wp_array_slice_assoc()`
* `_wp_array_get()`
* `_wp_array_set()`
* Renames the `$function` parameter to `$function_name` in:
* `_deprecated_function()`
* `_deprecated_argument()`
* `_doing_it_wrong()`
* Renames the `$class` parameter to `$class_name` in `_deprecated_constructor()`.
* Renames the `$default` parameter to `$default_value` in `apache_mod_loaded()`.
* Renames the `$var` parameter to `$value` in `wp_validate_boolean()`.
* Amends the `$input` parameter in `wp_parse_str()` for consistency.
Follow-up to [52946], [52996], [52997], [52998], [53003], [53014], [53029], [53039], [53116], [53117], [53137], [53174], [53184], [53185], [53192], [53193], [53198], [53203], [53207], [53215], [53216], [53220], [53230], [53232], [53236], [53239], [53240], [53242], [53243], [53245], [53246], [53257], [53269], [53270], [53271], [53272], [53273], [53274], [53275], [53276], [53277], [53281], [53283], [53284], [53285], [53287], [53364], [53365], [54927].
Props jrf, aristath, poena, justinahinon, SergeyBiryukov.
See #56788.
Built from https://develop.svn.wordpress.org/trunk@54929
git-svn-id: http://core.svn.wordpress.org/trunk@54481 1a063a9b-81f0-0310-95a4-ce76da25c4cd
2022-12-03 10:07:14 -05:00
* @ param array $input_array An array from which we want to retrieve some information .
* @ param array $path An array of keys describing the path with which to retrieve information .
* @ param mixed $default_value Optional . The return value if the path does not exist within the array ,
* or if `$input_array` or `$path` are not arrays . Default null .
2020-11-12 15:20:12 -05:00
* @ return mixed The value from the path specified .
2020-10-13 22:10:04 -04:00
*/
Code Modernization: Rename parameters that use reserved keywords in `wp-includes/functions.php`.
While using reserved PHP keywords as parameter name labels is allowed, in the context of function calls using named parameters in PHP 8.0+, this will easily lead to confusion. To avoid that, it is recommended not to use reserved keywords as function parameter names.
This commit:
* Renames the `$echo` parameter to `$display` in:
* `wp_nonce_field()`
* `wp_referer_field()`
* `wp_original_referer_field()`
* Renames the `$string` parameter to `$input_string` in
* `_wp_json_convert_string()`
* `_wp_to_kebab_case()`
* Renames the `$list` parameter to `$input_list` in:
* `wp_parse_list()`
* `wp_parse_id_list()`
* `wp_parse_slug_list()`
* `wp_filter_object_list()`
* `wp_list_filter()`
* `wp_list_pluck()`
* `wp_list_sort()`
* Renames the `$array` parameter to `$input_array` in:
* `add_magic_quotes()`
* `wp_array_slice_assoc()`
* `_wp_array_get()`
* `_wp_array_set()`
* Renames the `$function` parameter to `$function_name` in:
* `_deprecated_function()`
* `_deprecated_argument()`
* `_doing_it_wrong()`
* Renames the `$class` parameter to `$class_name` in `_deprecated_constructor()`.
* Renames the `$default` parameter to `$default_value` in `apache_mod_loaded()`.
* Renames the `$var` parameter to `$value` in `wp_validate_boolean()`.
* Amends the `$input` parameter in `wp_parse_str()` for consistency.
Follow-up to [52946], [52996], [52997], [52998], [53003], [53014], [53029], [53039], [53116], [53117], [53137], [53174], [53184], [53185], [53192], [53193], [53198], [53203], [53207], [53215], [53216], [53220], [53230], [53232], [53236], [53239], [53240], [53242], [53243], [53245], [53246], [53257], [53269], [53270], [53271], [53272], [53273], [53274], [53275], [53276], [53277], [53281], [53283], [53284], [53285], [53287], [53364], [53365], [54927].
Props jrf, aristath, poena, justinahinon, SergeyBiryukov.
See #56788.
Built from https://develop.svn.wordpress.org/trunk@54929
git-svn-id: http://core.svn.wordpress.org/trunk@54481 1a063a9b-81f0-0310-95a4-ce76da25c4cd
2022-12-03 10:07:14 -05:00
function _wp_array_get ( $input_array , $path , $default_value = null ) {
2020-11-12 15:20:12 -05:00
// Confirm $path is valid.
if ( ! is_array ( $path ) || 0 === count ( $path ) ) {
Code Modernization: Rename parameters that use reserved keywords in `wp-includes/functions.php`.
While using reserved PHP keywords as parameter name labels is allowed, in the context of function calls using named parameters in PHP 8.0+, this will easily lead to confusion. To avoid that, it is recommended not to use reserved keywords as function parameter names.
This commit:
* Renames the `$echo` parameter to `$display` in:
* `wp_nonce_field()`
* `wp_referer_field()`
* `wp_original_referer_field()`
* Renames the `$string` parameter to `$input_string` in
* `_wp_json_convert_string()`
* `_wp_to_kebab_case()`
* Renames the `$list` parameter to `$input_list` in:
* `wp_parse_list()`
* `wp_parse_id_list()`
* `wp_parse_slug_list()`
* `wp_filter_object_list()`
* `wp_list_filter()`
* `wp_list_pluck()`
* `wp_list_sort()`
* Renames the `$array` parameter to `$input_array` in:
* `add_magic_quotes()`
* `wp_array_slice_assoc()`
* `_wp_array_get()`
* `_wp_array_set()`
* Renames the `$function` parameter to `$function_name` in:
* `_deprecated_function()`
* `_deprecated_argument()`
* `_doing_it_wrong()`
* Renames the `$class` parameter to `$class_name` in `_deprecated_constructor()`.
* Renames the `$default` parameter to `$default_value` in `apache_mod_loaded()`.
* Renames the `$var` parameter to `$value` in `wp_validate_boolean()`.
* Amends the `$input` parameter in `wp_parse_str()` for consistency.
Follow-up to [52946], [52996], [52997], [52998], [53003], [53014], [53029], [53039], [53116], [53117], [53137], [53174], [53184], [53185], [53192], [53193], [53198], [53203], [53207], [53215], [53216], [53220], [53230], [53232], [53236], [53239], [53240], [53242], [53243], [53245], [53246], [53257], [53269], [53270], [53271], [53272], [53273], [53274], [53275], [53276], [53277], [53281], [53283], [53284], [53285], [53287], [53364], [53365], [54927].
Props jrf, aristath, poena, justinahinon, SergeyBiryukov.
See #56788.
Built from https://develop.svn.wordpress.org/trunk@54929
git-svn-id: http://core.svn.wordpress.org/trunk@54481 1a063a9b-81f0-0310-95a4-ce76da25c4cd
2022-12-03 10:07:14 -05:00
return $default_value ;
2020-10-13 22:10:04 -04:00
}
2020-11-12 15:20:12 -05:00
foreach ( $path as $path_element ) {
General: Improve performance of the `_wp_array_get()` function.
When using a block theme, `_wp_array_get()` is the most called function on the front end of a site.
This commit makes a few minor performance optimizations, which add up to a noticeable improvement.
Follow-up to [49135], [49143], [49580].
Props aristath, jrf, afercia, costdev, swissspidy, flixos90, spacedmonkey, mukesh27, samiamnot, SergeyBiryukov.
Fixes #58376.
Built from https://develop.svn.wordpress.org/trunk@55851
git-svn-id: http://core.svn.wordpress.org/trunk@55363 1a063a9b-81f0-0310-95a4-ce76da25c4cd
2023-05-23 18:00:21 -04:00
if ( ! is_array ( $input_array ) ) {
Code Modernization: Rename parameters that use reserved keywords in `wp-includes/functions.php`.
While using reserved PHP keywords as parameter name labels is allowed, in the context of function calls using named parameters in PHP 8.0+, this will easily lead to confusion. To avoid that, it is recommended not to use reserved keywords as function parameter names.
This commit:
* Renames the `$echo` parameter to `$display` in:
* `wp_nonce_field()`
* `wp_referer_field()`
* `wp_original_referer_field()`
* Renames the `$string` parameter to `$input_string` in
* `_wp_json_convert_string()`
* `_wp_to_kebab_case()`
* Renames the `$list` parameter to `$input_list` in:
* `wp_parse_list()`
* `wp_parse_id_list()`
* `wp_parse_slug_list()`
* `wp_filter_object_list()`
* `wp_list_filter()`
* `wp_list_pluck()`
* `wp_list_sort()`
* Renames the `$array` parameter to `$input_array` in:
* `add_magic_quotes()`
* `wp_array_slice_assoc()`
* `_wp_array_get()`
* `_wp_array_set()`
* Renames the `$function` parameter to `$function_name` in:
* `_deprecated_function()`
* `_deprecated_argument()`
* `_doing_it_wrong()`
* Renames the `$class` parameter to `$class_name` in `_deprecated_constructor()`.
* Renames the `$default` parameter to `$default_value` in `apache_mod_loaded()`.
* Renames the `$var` parameter to `$value` in `wp_validate_boolean()`.
* Amends the `$input` parameter in `wp_parse_str()` for consistency.
Follow-up to [52946], [52996], [52997], [52998], [53003], [53014], [53029], [53039], [53116], [53117], [53137], [53174], [53184], [53185], [53192], [53193], [53198], [53203], [53207], [53215], [53216], [53220], [53230], [53232], [53236], [53239], [53240], [53242], [53243], [53245], [53246], [53257], [53269], [53270], [53271], [53272], [53273], [53274], [53275], [53276], [53277], [53281], [53283], [53284], [53285], [53287], [53364], [53365], [54927].
Props jrf, aristath, poena, justinahinon, SergeyBiryukov.
See #56788.
Built from https://develop.svn.wordpress.org/trunk@54929
git-svn-id: http://core.svn.wordpress.org/trunk@54481 1a063a9b-81f0-0310-95a4-ce76da25c4cd
2022-12-03 10:07:14 -05:00
return $default_value ;
2020-10-13 22:10:04 -04:00
}
General: Improve performance of the `_wp_array_get()` function.
When using a block theme, `_wp_array_get()` is the most called function on the front end of a site.
This commit makes a few minor performance optimizations, which add up to a noticeable improvement.
Follow-up to [49135], [49143], [49580].
Props aristath, jrf, afercia, costdev, swissspidy, flixos90, spacedmonkey, mukesh27, samiamnot, SergeyBiryukov.
Fixes #58376.
Built from https://develop.svn.wordpress.org/trunk@55851
git-svn-id: http://core.svn.wordpress.org/trunk@55363 1a063a9b-81f0-0310-95a4-ce76da25c4cd
2023-05-23 18:00:21 -04:00
if ( is_string ( $path_element )
|| is_integer ( $path_element )
|| null === $path_element
) {
/*
* Check if the path element exists in the input array .
* We check with `isset()` first , as it is a lot faster
* than `array_key_exists()` .
*/
if ( isset ( $input_array [ $path_element ] ) ) {
$input_array = $input_array [ $path_element ];
continue ;
}
/*
* If `isset()` returns false , we check with `array_key_exists()` ,
* which also checks for `null` values .
*/
if ( array_key_exists ( $path_element , $input_array ) ) {
$input_array = $input_array [ $path_element ];
continue ;
}
}
return $default_value ;
2020-10-13 22:10:04 -04:00
}
Code Modernization: Rename parameters that use reserved keywords in `wp-includes/functions.php`.
While using reserved PHP keywords as parameter name labels is allowed, in the context of function calls using named parameters in PHP 8.0+, this will easily lead to confusion. To avoid that, it is recommended not to use reserved keywords as function parameter names.
This commit:
* Renames the `$echo` parameter to `$display` in:
* `wp_nonce_field()`
* `wp_referer_field()`
* `wp_original_referer_field()`
* Renames the `$string` parameter to `$input_string` in
* `_wp_json_convert_string()`
* `_wp_to_kebab_case()`
* Renames the `$list` parameter to `$input_list` in:
* `wp_parse_list()`
* `wp_parse_id_list()`
* `wp_parse_slug_list()`
* `wp_filter_object_list()`
* `wp_list_filter()`
* `wp_list_pluck()`
* `wp_list_sort()`
* Renames the `$array` parameter to `$input_array` in:
* `add_magic_quotes()`
* `wp_array_slice_assoc()`
* `_wp_array_get()`
* `_wp_array_set()`
* Renames the `$function` parameter to `$function_name` in:
* `_deprecated_function()`
* `_deprecated_argument()`
* `_doing_it_wrong()`
* Renames the `$class` parameter to `$class_name` in `_deprecated_constructor()`.
* Renames the `$default` parameter to `$default_value` in `apache_mod_loaded()`.
* Renames the `$var` parameter to `$value` in `wp_validate_boolean()`.
* Amends the `$input` parameter in `wp_parse_str()` for consistency.
Follow-up to [52946], [52996], [52997], [52998], [53003], [53014], [53029], [53039], [53116], [53117], [53137], [53174], [53184], [53185], [53192], [53193], [53198], [53203], [53207], [53215], [53216], [53220], [53230], [53232], [53236], [53239], [53240], [53242], [53243], [53245], [53246], [53257], [53269], [53270], [53271], [53272], [53273], [53274], [53275], [53276], [53277], [53281], [53283], [53284], [53285], [53287], [53364], [53365], [54927].
Props jrf, aristath, poena, justinahinon, SergeyBiryukov.
See #56788.
Built from https://develop.svn.wordpress.org/trunk@54929
git-svn-id: http://core.svn.wordpress.org/trunk@54481 1a063a9b-81f0-0310-95a4-ce76da25c4cd
2022-12-03 10:07:14 -05:00
return $input_array ;
2020-10-13 22:10:04 -04:00
}
2021-05-24 04:30:56 -04:00
/**
* Sets an array in depth based on a path of keys .
*
* It is the PHP equivalent of JavaScript ' s `lodash.set()` and mirroring it may help other components
* retain some symmetry between client and server implementations .
*
* Example usage :
*
Code Modernization: Rename parameters that use reserved keywords in `wp-includes/functions.php`.
While using reserved PHP keywords as parameter name labels is allowed, in the context of function calls using named parameters in PHP 8.0+, this will easily lead to confusion. To avoid that, it is recommended not to use reserved keywords as function parameter names.
This commit:
* Renames the `$echo` parameter to `$display` in:
* `wp_nonce_field()`
* `wp_referer_field()`
* `wp_original_referer_field()`
* Renames the `$string` parameter to `$input_string` in
* `_wp_json_convert_string()`
* `_wp_to_kebab_case()`
* Renames the `$list` parameter to `$input_list` in:
* `wp_parse_list()`
* `wp_parse_id_list()`
* `wp_parse_slug_list()`
* `wp_filter_object_list()`
* `wp_list_filter()`
* `wp_list_pluck()`
* `wp_list_sort()`
* Renames the `$array` parameter to `$input_array` in:
* `add_magic_quotes()`
* `wp_array_slice_assoc()`
* `_wp_array_get()`
* `_wp_array_set()`
* Renames the `$function` parameter to `$function_name` in:
* `_deprecated_function()`
* `_deprecated_argument()`
* `_doing_it_wrong()`
* Renames the `$class` parameter to `$class_name` in `_deprecated_constructor()`.
* Renames the `$default` parameter to `$default_value` in `apache_mod_loaded()`.
* Renames the `$var` parameter to `$value` in `wp_validate_boolean()`.
* Amends the `$input` parameter in `wp_parse_str()` for consistency.
Follow-up to [52946], [52996], [52997], [52998], [53003], [53014], [53029], [53039], [53116], [53117], [53137], [53174], [53184], [53185], [53192], [53193], [53198], [53203], [53207], [53215], [53216], [53220], [53230], [53232], [53236], [53239], [53240], [53242], [53243], [53245], [53246], [53257], [53269], [53270], [53271], [53272], [53273], [53274], [53275], [53276], [53277], [53281], [53283], [53284], [53285], [53287], [53364], [53365], [54927].
Props jrf, aristath, poena, justinahinon, SergeyBiryukov.
See #56788.
Built from https://develop.svn.wordpress.org/trunk@54929
git-svn-id: http://core.svn.wordpress.org/trunk@54481 1a063a9b-81f0-0310-95a4-ce76da25c4cd
2022-12-03 10:07:14 -05:00
* $input_array = array ();
* _wp_array_set ( $input_array , array ( 'a' , 'b' , 'c' , 1 ) );
2021-05-24 08:25:55 -04:00
*
Code Modernization: Rename parameters that use reserved keywords in `wp-includes/functions.php`.
While using reserved PHP keywords as parameter name labels is allowed, in the context of function calls using named parameters in PHP 8.0+, this will easily lead to confusion. To avoid that, it is recommended not to use reserved keywords as function parameter names.
This commit:
* Renames the `$echo` parameter to `$display` in:
* `wp_nonce_field()`
* `wp_referer_field()`
* `wp_original_referer_field()`
* Renames the `$string` parameter to `$input_string` in
* `_wp_json_convert_string()`
* `_wp_to_kebab_case()`
* Renames the `$list` parameter to `$input_list` in:
* `wp_parse_list()`
* `wp_parse_id_list()`
* `wp_parse_slug_list()`
* `wp_filter_object_list()`
* `wp_list_filter()`
* `wp_list_pluck()`
* `wp_list_sort()`
* Renames the `$array` parameter to `$input_array` in:
* `add_magic_quotes()`
* `wp_array_slice_assoc()`
* `_wp_array_get()`
* `_wp_array_set()`
* Renames the `$function` parameter to `$function_name` in:
* `_deprecated_function()`
* `_deprecated_argument()`
* `_doing_it_wrong()`
* Renames the `$class` parameter to `$class_name` in `_deprecated_constructor()`.
* Renames the `$default` parameter to `$default_value` in `apache_mod_loaded()`.
* Renames the `$var` parameter to `$value` in `wp_validate_boolean()`.
* Amends the `$input` parameter in `wp_parse_str()` for consistency.
Follow-up to [52946], [52996], [52997], [52998], [53003], [53014], [53029], [53039], [53116], [53117], [53137], [53174], [53184], [53185], [53192], [53193], [53198], [53203], [53207], [53215], [53216], [53220], [53230], [53232], [53236], [53239], [53240], [53242], [53243], [53245], [53246], [53257], [53269], [53270], [53271], [53272], [53273], [53274], [53275], [53276], [53277], [53281], [53283], [53284], [53285], [53287], [53364], [53365], [54927].
Props jrf, aristath, poena, justinahinon, SergeyBiryukov.
See #56788.
Built from https://develop.svn.wordpress.org/trunk@54929
git-svn-id: http://core.svn.wordpress.org/trunk@54481 1a063a9b-81f0-0310-95a4-ce76da25c4cd
2022-12-03 10:07:14 -05:00
* $input_array becomes :
2021-05-24 04:30:56 -04:00
* array (
* 'a' => array (
* 'b' => array (
* 'c' => 1 ,
* ),
* ),
* );
*
2021-05-24 08:25:55 -04:00
* @ internal
*
* @ since 5.8 . 0
* @ access private
*
Code Modernization: Rename parameters that use reserved keywords in `wp-includes/functions.php`.
While using reserved PHP keywords as parameter name labels is allowed, in the context of function calls using named parameters in PHP 8.0+, this will easily lead to confusion. To avoid that, it is recommended not to use reserved keywords as function parameter names.
This commit:
* Renames the `$echo` parameter to `$display` in:
* `wp_nonce_field()`
* `wp_referer_field()`
* `wp_original_referer_field()`
* Renames the `$string` parameter to `$input_string` in
* `_wp_json_convert_string()`
* `_wp_to_kebab_case()`
* Renames the `$list` parameter to `$input_list` in:
* `wp_parse_list()`
* `wp_parse_id_list()`
* `wp_parse_slug_list()`
* `wp_filter_object_list()`
* `wp_list_filter()`
* `wp_list_pluck()`
* `wp_list_sort()`
* Renames the `$array` parameter to `$input_array` in:
* `add_magic_quotes()`
* `wp_array_slice_assoc()`
* `_wp_array_get()`
* `_wp_array_set()`
* Renames the `$function` parameter to `$function_name` in:
* `_deprecated_function()`
* `_deprecated_argument()`
* `_doing_it_wrong()`
* Renames the `$class` parameter to `$class_name` in `_deprecated_constructor()`.
* Renames the `$default` parameter to `$default_value` in `apache_mod_loaded()`.
* Renames the `$var` parameter to `$value` in `wp_validate_boolean()`.
* Amends the `$input` parameter in `wp_parse_str()` for consistency.
Follow-up to [52946], [52996], [52997], [52998], [53003], [53014], [53029], [53039], [53116], [53117], [53137], [53174], [53184], [53185], [53192], [53193], [53198], [53203], [53207], [53215], [53216], [53220], [53230], [53232], [53236], [53239], [53240], [53242], [53243], [53245], [53246], [53257], [53269], [53270], [53271], [53272], [53273], [53274], [53275], [53276], [53277], [53281], [53283], [53284], [53285], [53287], [53364], [53365], [54927].
Props jrf, aristath, poena, justinahinon, SergeyBiryukov.
See #56788.
Built from https://develop.svn.wordpress.org/trunk@54929
git-svn-id: http://core.svn.wordpress.org/trunk@54481 1a063a9b-81f0-0310-95a4-ce76da25c4cd
2022-12-03 10:07:14 -05:00
* @ param array $input_array An array that we want to mutate to include a specific value in a path .
* @ param array $path An array of keys describing the path that we want to mutate .
* @ param mixed $value The value that will be set .
2021-05-24 04:30:56 -04:00
*/
Code Modernization: Rename parameters that use reserved keywords in `wp-includes/functions.php`.
While using reserved PHP keywords as parameter name labels is allowed, in the context of function calls using named parameters in PHP 8.0+, this will easily lead to confusion. To avoid that, it is recommended not to use reserved keywords as function parameter names.
This commit:
* Renames the `$echo` parameter to `$display` in:
* `wp_nonce_field()`
* `wp_referer_field()`
* `wp_original_referer_field()`
* Renames the `$string` parameter to `$input_string` in
* `_wp_json_convert_string()`
* `_wp_to_kebab_case()`
* Renames the `$list` parameter to `$input_list` in:
* `wp_parse_list()`
* `wp_parse_id_list()`
* `wp_parse_slug_list()`
* `wp_filter_object_list()`
* `wp_list_filter()`
* `wp_list_pluck()`
* `wp_list_sort()`
* Renames the `$array` parameter to `$input_array` in:
* `add_magic_quotes()`
* `wp_array_slice_assoc()`
* `_wp_array_get()`
* `_wp_array_set()`
* Renames the `$function` parameter to `$function_name` in:
* `_deprecated_function()`
* `_deprecated_argument()`
* `_doing_it_wrong()`
* Renames the `$class` parameter to `$class_name` in `_deprecated_constructor()`.
* Renames the `$default` parameter to `$default_value` in `apache_mod_loaded()`.
* Renames the `$var` parameter to `$value` in `wp_validate_boolean()`.
* Amends the `$input` parameter in `wp_parse_str()` for consistency.
Follow-up to [52946], [52996], [52997], [52998], [53003], [53014], [53029], [53039], [53116], [53117], [53137], [53174], [53184], [53185], [53192], [53193], [53198], [53203], [53207], [53215], [53216], [53220], [53230], [53232], [53236], [53239], [53240], [53242], [53243], [53245], [53246], [53257], [53269], [53270], [53271], [53272], [53273], [53274], [53275], [53276], [53277], [53281], [53283], [53284], [53285], [53287], [53364], [53365], [54927].
Props jrf, aristath, poena, justinahinon, SergeyBiryukov.
See #56788.
Built from https://develop.svn.wordpress.org/trunk@54929
git-svn-id: http://core.svn.wordpress.org/trunk@54481 1a063a9b-81f0-0310-95a4-ce76da25c4cd
2022-12-03 10:07:14 -05:00
function _wp_array_set ( & $input_array , $path , $value = null ) {
// Confirm $input_array is valid.
if ( ! is_array ( $input_array ) ) {
2021-05-24 04:30:56 -04:00
return ;
}
// Confirm $path is valid.
if ( ! is_array ( $path ) ) {
return ;
}
2021-05-24 08:25:55 -04:00
2021-05-24 04:30:56 -04:00
$path_length = count ( $path );
2021-05-24 08:25:55 -04:00
2021-05-24 04:30:56 -04:00
if ( 0 === $path_length ) {
return ;
}
2021-05-24 08:25:55 -04:00
2021-05-24 04:30:56 -04:00
foreach ( $path as $path_element ) {
if (
! is_string ( $path_element ) && ! is_integer ( $path_element ) &&
! is_null ( $path_element )
) {
return ;
}
}
for ( $i = 0 ; $i < $path_length - 1 ; ++ $i ) {
$path_element = $path [ $i ];
if (
Code Modernization: Rename parameters that use reserved keywords in `wp-includes/functions.php`.
While using reserved PHP keywords as parameter name labels is allowed, in the context of function calls using named parameters in PHP 8.0+, this will easily lead to confusion. To avoid that, it is recommended not to use reserved keywords as function parameter names.
This commit:
* Renames the `$echo` parameter to `$display` in:
* `wp_nonce_field()`
* `wp_referer_field()`
* `wp_original_referer_field()`
* Renames the `$string` parameter to `$input_string` in
* `_wp_json_convert_string()`
* `_wp_to_kebab_case()`
* Renames the `$list` parameter to `$input_list` in:
* `wp_parse_list()`
* `wp_parse_id_list()`
* `wp_parse_slug_list()`
* `wp_filter_object_list()`
* `wp_list_filter()`
* `wp_list_pluck()`
* `wp_list_sort()`
* Renames the `$array` parameter to `$input_array` in:
* `add_magic_quotes()`
* `wp_array_slice_assoc()`
* `_wp_array_get()`
* `_wp_array_set()`
* Renames the `$function` parameter to `$function_name` in:
* `_deprecated_function()`
* `_deprecated_argument()`
* `_doing_it_wrong()`
* Renames the `$class` parameter to `$class_name` in `_deprecated_constructor()`.
* Renames the `$default` parameter to `$default_value` in `apache_mod_loaded()`.
* Renames the `$var` parameter to `$value` in `wp_validate_boolean()`.
* Amends the `$input` parameter in `wp_parse_str()` for consistency.
Follow-up to [52946], [52996], [52997], [52998], [53003], [53014], [53029], [53039], [53116], [53117], [53137], [53174], [53184], [53185], [53192], [53193], [53198], [53203], [53207], [53215], [53216], [53220], [53230], [53232], [53236], [53239], [53240], [53242], [53243], [53245], [53246], [53257], [53269], [53270], [53271], [53272], [53273], [53274], [53275], [53276], [53277], [53281], [53283], [53284], [53285], [53287], [53364], [53365], [54927].
Props jrf, aristath, poena, justinahinon, SergeyBiryukov.
See #56788.
Built from https://develop.svn.wordpress.org/trunk@54929
git-svn-id: http://core.svn.wordpress.org/trunk@54481 1a063a9b-81f0-0310-95a4-ce76da25c4cd
2022-12-03 10:07:14 -05:00
! array_key_exists ( $path_element , $input_array ) ||
! is_array ( $input_array [ $path_element ] )
2021-05-24 04:30:56 -04:00
) {
Code Modernization: Rename parameters that use reserved keywords in `wp-includes/functions.php`.
While using reserved PHP keywords as parameter name labels is allowed, in the context of function calls using named parameters in PHP 8.0+, this will easily lead to confusion. To avoid that, it is recommended not to use reserved keywords as function parameter names.
This commit:
* Renames the `$echo` parameter to `$display` in:
* `wp_nonce_field()`
* `wp_referer_field()`
* `wp_original_referer_field()`
* Renames the `$string` parameter to `$input_string` in
* `_wp_json_convert_string()`
* `_wp_to_kebab_case()`
* Renames the `$list` parameter to `$input_list` in:
* `wp_parse_list()`
* `wp_parse_id_list()`
* `wp_parse_slug_list()`
* `wp_filter_object_list()`
* `wp_list_filter()`
* `wp_list_pluck()`
* `wp_list_sort()`
* Renames the `$array` parameter to `$input_array` in:
* `add_magic_quotes()`
* `wp_array_slice_assoc()`
* `_wp_array_get()`
* `_wp_array_set()`
* Renames the `$function` parameter to `$function_name` in:
* `_deprecated_function()`
* `_deprecated_argument()`
* `_doing_it_wrong()`
* Renames the `$class` parameter to `$class_name` in `_deprecated_constructor()`.
* Renames the `$default` parameter to `$default_value` in `apache_mod_loaded()`.
* Renames the `$var` parameter to `$value` in `wp_validate_boolean()`.
* Amends the `$input` parameter in `wp_parse_str()` for consistency.
Follow-up to [52946], [52996], [52997], [52998], [53003], [53014], [53029], [53039], [53116], [53117], [53137], [53174], [53184], [53185], [53192], [53193], [53198], [53203], [53207], [53215], [53216], [53220], [53230], [53232], [53236], [53239], [53240], [53242], [53243], [53245], [53246], [53257], [53269], [53270], [53271], [53272], [53273], [53274], [53275], [53276], [53277], [53281], [53283], [53284], [53285], [53287], [53364], [53365], [54927].
Props jrf, aristath, poena, justinahinon, SergeyBiryukov.
See #56788.
Built from https://develop.svn.wordpress.org/trunk@54929
git-svn-id: http://core.svn.wordpress.org/trunk@54481 1a063a9b-81f0-0310-95a4-ce76da25c4cd
2022-12-03 10:07:14 -05:00
$input_array [ $path_element ] = array ();
2021-05-24 04:30:56 -04:00
}
Code Modernization: Rename parameters that use reserved keywords in `wp-includes/functions.php`.
While using reserved PHP keywords as parameter name labels is allowed, in the context of function calls using named parameters in PHP 8.0+, this will easily lead to confusion. To avoid that, it is recommended not to use reserved keywords as function parameter names.
This commit:
* Renames the `$echo` parameter to `$display` in:
* `wp_nonce_field()`
* `wp_referer_field()`
* `wp_original_referer_field()`
* Renames the `$string` parameter to `$input_string` in
* `_wp_json_convert_string()`
* `_wp_to_kebab_case()`
* Renames the `$list` parameter to `$input_list` in:
* `wp_parse_list()`
* `wp_parse_id_list()`
* `wp_parse_slug_list()`
* `wp_filter_object_list()`
* `wp_list_filter()`
* `wp_list_pluck()`
* `wp_list_sort()`
* Renames the `$array` parameter to `$input_array` in:
* `add_magic_quotes()`
* `wp_array_slice_assoc()`
* `_wp_array_get()`
* `_wp_array_set()`
* Renames the `$function` parameter to `$function_name` in:
* `_deprecated_function()`
* `_deprecated_argument()`
* `_doing_it_wrong()`
* Renames the `$class` parameter to `$class_name` in `_deprecated_constructor()`.
* Renames the `$default` parameter to `$default_value` in `apache_mod_loaded()`.
* Renames the `$var` parameter to `$value` in `wp_validate_boolean()`.
* Amends the `$input` parameter in `wp_parse_str()` for consistency.
Follow-up to [52946], [52996], [52997], [52998], [53003], [53014], [53029], [53039], [53116], [53117], [53137], [53174], [53184], [53185], [53192], [53193], [53198], [53203], [53207], [53215], [53216], [53220], [53230], [53232], [53236], [53239], [53240], [53242], [53243], [53245], [53246], [53257], [53269], [53270], [53271], [53272], [53273], [53274], [53275], [53276], [53277], [53281], [53283], [53284], [53285], [53287], [53364], [53365], [54927].
Props jrf, aristath, poena, justinahinon, SergeyBiryukov.
See #56788.
Built from https://develop.svn.wordpress.org/trunk@54929
git-svn-id: http://core.svn.wordpress.org/trunk@54481 1a063a9b-81f0-0310-95a4-ce76da25c4cd
2022-12-03 10:07:14 -05:00
$input_array = & $input_array [ $path_element ]; // phpcs:ignore VariableAnalysis.CodeAnalysis.VariableAnalysis.VariableRedeclaration
2021-05-24 04:30:56 -04:00
}
2021-05-24 08:25:55 -04:00
Code Modernization: Rename parameters that use reserved keywords in `wp-includes/functions.php`.
While using reserved PHP keywords as parameter name labels is allowed, in the context of function calls using named parameters in PHP 8.0+, this will easily lead to confusion. To avoid that, it is recommended not to use reserved keywords as function parameter names.
This commit:
* Renames the `$echo` parameter to `$display` in:
* `wp_nonce_field()`
* `wp_referer_field()`
* `wp_original_referer_field()`
* Renames the `$string` parameter to `$input_string` in
* `_wp_json_convert_string()`
* `_wp_to_kebab_case()`
* Renames the `$list` parameter to `$input_list` in:
* `wp_parse_list()`
* `wp_parse_id_list()`
* `wp_parse_slug_list()`
* `wp_filter_object_list()`
* `wp_list_filter()`
* `wp_list_pluck()`
* `wp_list_sort()`
* Renames the `$array` parameter to `$input_array` in:
* `add_magic_quotes()`
* `wp_array_slice_assoc()`
* `_wp_array_get()`
* `_wp_array_set()`
* Renames the `$function` parameter to `$function_name` in:
* `_deprecated_function()`
* `_deprecated_argument()`
* `_doing_it_wrong()`
* Renames the `$class` parameter to `$class_name` in `_deprecated_constructor()`.
* Renames the `$default` parameter to `$default_value` in `apache_mod_loaded()`.
* Renames the `$var` parameter to `$value` in `wp_validate_boolean()`.
* Amends the `$input` parameter in `wp_parse_str()` for consistency.
Follow-up to [52946], [52996], [52997], [52998], [53003], [53014], [53029], [53039], [53116], [53117], [53137], [53174], [53184], [53185], [53192], [53193], [53198], [53203], [53207], [53215], [53216], [53220], [53230], [53232], [53236], [53239], [53240], [53242], [53243], [53245], [53246], [53257], [53269], [53270], [53271], [53272], [53273], [53274], [53275], [53276], [53277], [53281], [53283], [53284], [53285], [53287], [53364], [53365], [54927].
Props jrf, aristath, poena, justinahinon, SergeyBiryukov.
See #56788.
Built from https://develop.svn.wordpress.org/trunk@54929
git-svn-id: http://core.svn.wordpress.org/trunk@54481 1a063a9b-81f0-0310-95a4-ce76da25c4cd
2022-12-03 10:07:14 -05:00
$input_array [ $path [ $i ] ] = $value ;
2021-05-24 04:30:56 -04:00
}
2021-06-22 05:51:00 -04:00
/**
* This function is trying to replicate what
* lodash ' s kebabCase ( JS library ) does in the client .
*
* The reason we need this function is that we do some processing
* in both the client and the server ( e . g .: we generate
* preset classes from preset slugs ) that needs to
* create the same output .
*
* We can 't remove or update the client' s library due to backward compatibility
* ( some of the output of lodash ' s kebabCase is saved in the post content ) .
* We have to make the server behave like the client .
*
* Changes to this function should follow updates in the client
* with the same logic .
*
* @ link https :// github . com / lodash / lodash / blob / 4.17 / dist / lodash . js #L14369
* @ link https :// github . com / lodash / lodash / blob / 4.17 / dist / lodash . js #L278
* @ link https :// github . com / lodash - php / lodash - php / blob / master / src / String / kebabCase . php
* @ link https :// github . com / lodash - php / lodash - php / blob / master / src / internal / unicodeWords . php
*
Code Modernization: Rename parameters that use reserved keywords in `wp-includes/functions.php`.
While using reserved PHP keywords as parameter name labels is allowed, in the context of function calls using named parameters in PHP 8.0+, this will easily lead to confusion. To avoid that, it is recommended not to use reserved keywords as function parameter names.
This commit:
* Renames the `$echo` parameter to `$display` in:
* `wp_nonce_field()`
* `wp_referer_field()`
* `wp_original_referer_field()`
* Renames the `$string` parameter to `$input_string` in
* `_wp_json_convert_string()`
* `_wp_to_kebab_case()`
* Renames the `$list` parameter to `$input_list` in:
* `wp_parse_list()`
* `wp_parse_id_list()`
* `wp_parse_slug_list()`
* `wp_filter_object_list()`
* `wp_list_filter()`
* `wp_list_pluck()`
* `wp_list_sort()`
* Renames the `$array` parameter to `$input_array` in:
* `add_magic_quotes()`
* `wp_array_slice_assoc()`
* `_wp_array_get()`
* `_wp_array_set()`
* Renames the `$function` parameter to `$function_name` in:
* `_deprecated_function()`
* `_deprecated_argument()`
* `_doing_it_wrong()`
* Renames the `$class` parameter to `$class_name` in `_deprecated_constructor()`.
* Renames the `$default` parameter to `$default_value` in `apache_mod_loaded()`.
* Renames the `$var` parameter to `$value` in `wp_validate_boolean()`.
* Amends the `$input` parameter in `wp_parse_str()` for consistency.
Follow-up to [52946], [52996], [52997], [52998], [53003], [53014], [53029], [53039], [53116], [53117], [53137], [53174], [53184], [53185], [53192], [53193], [53198], [53203], [53207], [53215], [53216], [53220], [53230], [53232], [53236], [53239], [53240], [53242], [53243], [53245], [53246], [53257], [53269], [53270], [53271], [53272], [53273], [53274], [53275], [53276], [53277], [53281], [53283], [53284], [53285], [53287], [53364], [53365], [54927].
Props jrf, aristath, poena, justinahinon, SergeyBiryukov.
See #56788.
Built from https://develop.svn.wordpress.org/trunk@54929
git-svn-id: http://core.svn.wordpress.org/trunk@54481 1a063a9b-81f0-0310-95a4-ce76da25c4cd
2022-12-03 10:07:14 -05:00
* @ param string $input_string The string to kebab - case .
2021-06-22 05:51:00 -04:00
*
* @ return string kebab - cased - string .
*/
Code Modernization: Rename parameters that use reserved keywords in `wp-includes/functions.php`.
While using reserved PHP keywords as parameter name labels is allowed, in the context of function calls using named parameters in PHP 8.0+, this will easily lead to confusion. To avoid that, it is recommended not to use reserved keywords as function parameter names.
This commit:
* Renames the `$echo` parameter to `$display` in:
* `wp_nonce_field()`
* `wp_referer_field()`
* `wp_original_referer_field()`
* Renames the `$string` parameter to `$input_string` in
* `_wp_json_convert_string()`
* `_wp_to_kebab_case()`
* Renames the `$list` parameter to `$input_list` in:
* `wp_parse_list()`
* `wp_parse_id_list()`
* `wp_parse_slug_list()`
* `wp_filter_object_list()`
* `wp_list_filter()`
* `wp_list_pluck()`
* `wp_list_sort()`
* Renames the `$array` parameter to `$input_array` in:
* `add_magic_quotes()`
* `wp_array_slice_assoc()`
* `_wp_array_get()`
* `_wp_array_set()`
* Renames the `$function` parameter to `$function_name` in:
* `_deprecated_function()`
* `_deprecated_argument()`
* `_doing_it_wrong()`
* Renames the `$class` parameter to `$class_name` in `_deprecated_constructor()`.
* Renames the `$default` parameter to `$default_value` in `apache_mod_loaded()`.
* Renames the `$var` parameter to `$value` in `wp_validate_boolean()`.
* Amends the `$input` parameter in `wp_parse_str()` for consistency.
Follow-up to [52946], [52996], [52997], [52998], [53003], [53014], [53029], [53039], [53116], [53117], [53137], [53174], [53184], [53185], [53192], [53193], [53198], [53203], [53207], [53215], [53216], [53220], [53230], [53232], [53236], [53239], [53240], [53242], [53243], [53245], [53246], [53257], [53269], [53270], [53271], [53272], [53273], [53274], [53275], [53276], [53277], [53281], [53283], [53284], [53285], [53287], [53364], [53365], [54927].
Props jrf, aristath, poena, justinahinon, SergeyBiryukov.
See #56788.
Built from https://develop.svn.wordpress.org/trunk@54929
git-svn-id: http://core.svn.wordpress.org/trunk@54481 1a063a9b-81f0-0310-95a4-ce76da25c4cd
2022-12-03 10:07:14 -05:00
function _wp_to_kebab_case ( $input_string ) {
2023-07-10 18:38:25 -04:00
// Ignore the camelCase names for variables so the names are the same as lodash so comparing and porting new changes is easier.
// phpcs:disable WordPress.NamingConventions.ValidVariableName.VariableNotSnakeCase
2021-06-22 05:51:00 -04:00
/*
* Some notable things we ' ve removed compared to the lodash version are :
*
* - non - alphanumeric characters : rsAstralRange , rsEmoji , etc
* - the groups that processed the apostrophe , as it ' s removed before passing the string to preg_match : rsApos , rsOptContrLower , and rsOptContrUpper
*
*/
/** Used to compose unicode character classes. */
$rsLowerRange = 'a-z\\xdf-\\xf6\\xf8-\\xff' ;
$rsNonCharRange = '\\x00-\\x2f\\x3a-\\x40\\x5b-\\x60\\x7b-\\xbf' ;
$rsPunctuationRange = '\\x{2000}-\\x{206f}' ;
$rsSpaceRange = ' \\t\\x0b\\f\\xa0\\x{feff}\\n\\r\\x{2028}\\x{2029}\\x{1680}\\x{180e}\\x{2000}\\x{2001}\\x{2002}\\x{2003}\\x{2004}\\x{2005}\\x{2006}\\x{2007}\\x{2008}\\x{2009}\\x{200a}\\x{202f}\\x{205f}\\x{3000}' ;
$rsUpperRange = 'A-Z\\xc0-\\xd6\\xd8-\\xde' ;
$rsBreakRange = $rsNonCharRange . $rsPunctuationRange . $rsSpaceRange ;
/** Used to compose unicode capture groups. */
$rsBreak = '[' . $rsBreakRange . ']' ;
$rsDigits = '\\d+' ; // The last lodash version in GitHub uses a single digit here and expands it when in use.
$rsLower = '[' . $rsLowerRange . ']' ;
$rsMisc = '[^' . $rsBreakRange . $rsDigits . $rsLowerRange . $rsUpperRange . ']' ;
$rsUpper = '[' . $rsUpperRange . ']' ;
/** Used to compose unicode regexes. */
$rsMiscLower = '(?:' . $rsLower . '|' . $rsMisc . ')' ;
$rsMiscUpper = '(?:' . $rsUpper . '|' . $rsMisc . ')' ;
$rsOrdLower = '\\d*(?:1st|2nd|3rd|(?![123])\\dth)(?=\\b|[A-Z_])' ;
$rsOrdUpper = '\\d*(?:1ST|2ND|3RD|(?![123])\\dTH)(?=\\b|[a-z_])' ;
$regexp = '/' . implode (
'|' ,
array (
$rsUpper . '?' . $rsLower . '+' . '(?=' . implode ( '|' , array ( $rsBreak , $rsUpper , '$' ) ) . ')' ,
$rsMiscUpper . '+' . '(?=' . implode ( '|' , array ( $rsBreak , $rsUpper . $rsMiscLower , '$' ) ) . ')' ,
$rsUpper . '?' . $rsMiscLower . '+' ,
$rsUpper . '+' ,
$rsOrdUpper ,
$rsOrdLower ,
$rsDigits ,
)
) . '/u' ;
Code Modernization: Rename parameters that use reserved keywords in `wp-includes/functions.php`.
While using reserved PHP keywords as parameter name labels is allowed, in the context of function calls using named parameters in PHP 8.0+, this will easily lead to confusion. To avoid that, it is recommended not to use reserved keywords as function parameter names.
This commit:
* Renames the `$echo` parameter to `$display` in:
* `wp_nonce_field()`
* `wp_referer_field()`
* `wp_original_referer_field()`
* Renames the `$string` parameter to `$input_string` in
* `_wp_json_convert_string()`
* `_wp_to_kebab_case()`
* Renames the `$list` parameter to `$input_list` in:
* `wp_parse_list()`
* `wp_parse_id_list()`
* `wp_parse_slug_list()`
* `wp_filter_object_list()`
* `wp_list_filter()`
* `wp_list_pluck()`
* `wp_list_sort()`
* Renames the `$array` parameter to `$input_array` in:
* `add_magic_quotes()`
* `wp_array_slice_assoc()`
* `_wp_array_get()`
* `_wp_array_set()`
* Renames the `$function` parameter to `$function_name` in:
* `_deprecated_function()`
* `_deprecated_argument()`
* `_doing_it_wrong()`
* Renames the `$class` parameter to `$class_name` in `_deprecated_constructor()`.
* Renames the `$default` parameter to `$default_value` in `apache_mod_loaded()`.
* Renames the `$var` parameter to `$value` in `wp_validate_boolean()`.
* Amends the `$input` parameter in `wp_parse_str()` for consistency.
Follow-up to [52946], [52996], [52997], [52998], [53003], [53014], [53029], [53039], [53116], [53117], [53137], [53174], [53184], [53185], [53192], [53193], [53198], [53203], [53207], [53215], [53216], [53220], [53230], [53232], [53236], [53239], [53240], [53242], [53243], [53245], [53246], [53257], [53269], [53270], [53271], [53272], [53273], [53274], [53275], [53276], [53277], [53281], [53283], [53284], [53285], [53287], [53364], [53365], [54927].
Props jrf, aristath, poena, justinahinon, SergeyBiryukov.
See #56788.
Built from https://develop.svn.wordpress.org/trunk@54929
git-svn-id: http://core.svn.wordpress.org/trunk@54481 1a063a9b-81f0-0310-95a4-ce76da25c4cd
2022-12-03 10:07:14 -05:00
preg_match_all ( $regexp , str_replace ( " ' " , '' , $input_string ), $matches );
2021-06-22 05:51:00 -04:00
return strtolower ( implode ( '-' , $matches [ 0 ] ) );
//phpcs:enable WordPress.NamingConventions.ValidVariableName.VariableNotSnakeCase
}
2020-10-13 22:16:08 -04:00
/**
* Determines if the variable is a numeric - indexed array .
*
* @ since 4.4 . 0
*
* @ param mixed $data Variable to check .
* @ return bool Whether the variable is a list .
*/
function wp_is_numeric_array ( $data ) {
if ( ! is_array ( $data ) ) {
return false ;
}
$keys = array_keys ( $data );
$string_keys = array_filter ( $keys , 'is_string' );
return count ( $string_keys ) === 0 ;
}
2010-04-16 10:08:58 -04:00
/**
2011-07-21 13:48:25 -04:00
* Filters a list of objects , based on a set of key => value arguments .
2010-04-16 10:08:58 -04:00
*
2021-05-28 14:04:57 -04:00
* Retrieves the objects from the list that match the given arguments .
* Key represents property name , and value represents property value .
*
* If an object has more properties than those specified in arguments ,
* that will not disqualify it . When using the 'AND' operator ,
* any missing properties will disqualify it .
*
* When using the `$field` argument , this function can also retrieve
* a particular field from all matching objects , whereas wp_list_filter ()
* only does the filtering .
*
2010-04-16 10:08:58 -04:00
* @ since 3.0 . 0
2018-02-09 11:55:31 -05:00
* @ since 4.7 . 0 Uses `WP_List_Util` class .
2010-04-16 10:08:58 -04:00
*
Code Modernization: Rename parameters that use reserved keywords in `wp-includes/functions.php`.
While using reserved PHP keywords as parameter name labels is allowed, in the context of function calls using named parameters in PHP 8.0+, this will easily lead to confusion. To avoid that, it is recommended not to use reserved keywords as function parameter names.
This commit:
* Renames the `$echo` parameter to `$display` in:
* `wp_nonce_field()`
* `wp_referer_field()`
* `wp_original_referer_field()`
* Renames the `$string` parameter to `$input_string` in
* `_wp_json_convert_string()`
* `_wp_to_kebab_case()`
* Renames the `$list` parameter to `$input_list` in:
* `wp_parse_list()`
* `wp_parse_id_list()`
* `wp_parse_slug_list()`
* `wp_filter_object_list()`
* `wp_list_filter()`
* `wp_list_pluck()`
* `wp_list_sort()`
* Renames the `$array` parameter to `$input_array` in:
* `add_magic_quotes()`
* `wp_array_slice_assoc()`
* `_wp_array_get()`
* `_wp_array_set()`
* Renames the `$function` parameter to `$function_name` in:
* `_deprecated_function()`
* `_deprecated_argument()`
* `_doing_it_wrong()`
* Renames the `$class` parameter to `$class_name` in `_deprecated_constructor()`.
* Renames the `$default` parameter to `$default_value` in `apache_mod_loaded()`.
* Renames the `$var` parameter to `$value` in `wp_validate_boolean()`.
* Amends the `$input` parameter in `wp_parse_str()` for consistency.
Follow-up to [52946], [52996], [52997], [52998], [53003], [53014], [53029], [53039], [53116], [53117], [53137], [53174], [53184], [53185], [53192], [53193], [53198], [53203], [53207], [53215], [53216], [53220], [53230], [53232], [53236], [53239], [53240], [53242], [53243], [53245], [53246], [53257], [53269], [53270], [53271], [53272], [53273], [53274], [53275], [53276], [53277], [53281], [53283], [53284], [53285], [53287], [53364], [53365], [54927].
Props jrf, aristath, poena, justinahinon, SergeyBiryukov.
See #56788.
Built from https://develop.svn.wordpress.org/trunk@54929
git-svn-id: http://core.svn.wordpress.org/trunk@54481 1a063a9b-81f0-0310-95a4-ce76da25c4cd
2022-12-03 10:07:14 -05:00
* @ param array $input_list An array of objects to filter .
* @ param array $args Optional . An array of key => value arguments to match
* against each object . Default empty array .
* @ param string $operator Optional . The logical operation to perform . 'AND' means
* all elements from the array must match . 'OR' means only
* one element needs to match . 'NOT' means no elements may
* match . Default 'AND' .
* @ param bool | string $field Optional . A field from the object to place instead
* of the entire object . Default false .
2014-06-30 21:44:15 -04:00
* @ return array A list of objects or object fields .
2010-04-16 10:08:58 -04:00
*/
Code Modernization: Rename parameters that use reserved keywords in `wp-includes/functions.php`.
While using reserved PHP keywords as parameter name labels is allowed, in the context of function calls using named parameters in PHP 8.0+, this will easily lead to confusion. To avoid that, it is recommended not to use reserved keywords as function parameter names.
This commit:
* Renames the `$echo` parameter to `$display` in:
* `wp_nonce_field()`
* `wp_referer_field()`
* `wp_original_referer_field()`
* Renames the `$string` parameter to `$input_string` in
* `_wp_json_convert_string()`
* `_wp_to_kebab_case()`
* Renames the `$list` parameter to `$input_list` in:
* `wp_parse_list()`
* `wp_parse_id_list()`
* `wp_parse_slug_list()`
* `wp_filter_object_list()`
* `wp_list_filter()`
* `wp_list_pluck()`
* `wp_list_sort()`
* Renames the `$array` parameter to `$input_array` in:
* `add_magic_quotes()`
* `wp_array_slice_assoc()`
* `_wp_array_get()`
* `_wp_array_set()`
* Renames the `$function` parameter to `$function_name` in:
* `_deprecated_function()`
* `_deprecated_argument()`
* `_doing_it_wrong()`
* Renames the `$class` parameter to `$class_name` in `_deprecated_constructor()`.
* Renames the `$default` parameter to `$default_value` in `apache_mod_loaded()`.
* Renames the `$var` parameter to `$value` in `wp_validate_boolean()`.
* Amends the `$input` parameter in `wp_parse_str()` for consistency.
Follow-up to [52946], [52996], [52997], [52998], [53003], [53014], [53029], [53039], [53116], [53117], [53137], [53174], [53184], [53185], [53192], [53193], [53198], [53203], [53207], [53215], [53216], [53220], [53230], [53232], [53236], [53239], [53240], [53242], [53243], [53245], [53246], [53257], [53269], [53270], [53271], [53272], [53273], [53274], [53275], [53276], [53277], [53281], [53283], [53284], [53285], [53287], [53364], [53365], [54927].
Props jrf, aristath, poena, justinahinon, SergeyBiryukov.
See #56788.
Built from https://develop.svn.wordpress.org/trunk@54929
git-svn-id: http://core.svn.wordpress.org/trunk@54481 1a063a9b-81f0-0310-95a4-ce76da25c4cd
2022-12-03 10:07:14 -05:00
function wp_filter_object_list ( $input_list , $args = array (), $operator = 'and' , $field = false ) {
if ( ! is_array ( $input_list ) ) {
2011-02-09 12:06:22 -05:00
return array ();
2016-10-25 17:26:32 -04:00
}
2011-02-09 12:06:22 -05:00
Code Modernization: Rename parameters that use reserved keywords in `wp-includes/functions.php`.
While using reserved PHP keywords as parameter name labels is allowed, in the context of function calls using named parameters in PHP 8.0+, this will easily lead to confusion. To avoid that, it is recommended not to use reserved keywords as function parameter names.
This commit:
* Renames the `$echo` parameter to `$display` in:
* `wp_nonce_field()`
* `wp_referer_field()`
* `wp_original_referer_field()`
* Renames the `$string` parameter to `$input_string` in
* `_wp_json_convert_string()`
* `_wp_to_kebab_case()`
* Renames the `$list` parameter to `$input_list` in:
* `wp_parse_list()`
* `wp_parse_id_list()`
* `wp_parse_slug_list()`
* `wp_filter_object_list()`
* `wp_list_filter()`
* `wp_list_pluck()`
* `wp_list_sort()`
* Renames the `$array` parameter to `$input_array` in:
* `add_magic_quotes()`
* `wp_array_slice_assoc()`
* `_wp_array_get()`
* `_wp_array_set()`
* Renames the `$function` parameter to `$function_name` in:
* `_deprecated_function()`
* `_deprecated_argument()`
* `_doing_it_wrong()`
* Renames the `$class` parameter to `$class_name` in `_deprecated_constructor()`.
* Renames the `$default` parameter to `$default_value` in `apache_mod_loaded()`.
* Renames the `$var` parameter to `$value` in `wp_validate_boolean()`.
* Amends the `$input` parameter in `wp_parse_str()` for consistency.
Follow-up to [52946], [52996], [52997], [52998], [53003], [53014], [53029], [53039], [53116], [53117], [53137], [53174], [53184], [53185], [53192], [53193], [53198], [53203], [53207], [53215], [53216], [53220], [53230], [53232], [53236], [53239], [53240], [53242], [53243], [53245], [53246], [53257], [53269], [53270], [53271], [53272], [53273], [53274], [53275], [53276], [53277], [53281], [53283], [53284], [53285], [53287], [53364], [53365], [54927].
Props jrf, aristath, poena, justinahinon, SergeyBiryukov.
See #56788.
Built from https://develop.svn.wordpress.org/trunk@54929
git-svn-id: http://core.svn.wordpress.org/trunk@54481 1a063a9b-81f0-0310-95a4-ce76da25c4cd
2022-12-03 10:07:14 -05:00
$util = new WP_List_Util ( $input_list );
2010-04-16 10:08:58 -04:00
2016-10-25 17:26:32 -04:00
$util -> filter ( $args , $operator );
2010-10-02 14:48:51 -04:00
2016-10-25 17:26:32 -04:00
if ( $field ) {
$util -> pluck ( $field );
}
return $util -> get_output ();
2010-10-02 14:48:51 -04:00
}
2010-04-16 10:08:58 -04:00
2010-10-02 14:48:51 -04:00
/**
2011-07-21 13:48:25 -04:00
* Filters a list of objects , based on a set of key => value arguments .
2010-10-02 14:48:51 -04:00
*
2021-05-28 14:04:57 -04:00
* Retrieves the objects from the list that match the given arguments .
* Key represents property name , and value represents property value .
*
* If an object has more properties than those specified in arguments ,
* that will not disqualify it . When using the 'AND' operator ,
* any missing properties will disqualify it .
*
* If you want to retrieve a particular field from all matching objects ,
* use wp_filter_object_list () instead .
*
2010-10-02 14:48:51 -04:00
* @ since 3.1 . 0
2018-02-09 11:55:31 -05:00
* @ since 4.7 . 0 Uses `WP_List_Util` class .
2021-11-08 20:10:59 -05:00
* @ since 5.9 . 0 Converted into a wrapper for `wp_filter_object_list()` .
2010-10-02 14:48:51 -04:00
*
Code Modernization: Rename parameters that use reserved keywords in `wp-includes/functions.php`.
While using reserved PHP keywords as parameter name labels is allowed, in the context of function calls using named parameters in PHP 8.0+, this will easily lead to confusion. To avoid that, it is recommended not to use reserved keywords as function parameter names.
This commit:
* Renames the `$echo` parameter to `$display` in:
* `wp_nonce_field()`
* `wp_referer_field()`
* `wp_original_referer_field()`
* Renames the `$string` parameter to `$input_string` in
* `_wp_json_convert_string()`
* `_wp_to_kebab_case()`
* Renames the `$list` parameter to `$input_list` in:
* `wp_parse_list()`
* `wp_parse_id_list()`
* `wp_parse_slug_list()`
* `wp_filter_object_list()`
* `wp_list_filter()`
* `wp_list_pluck()`
* `wp_list_sort()`
* Renames the `$array` parameter to `$input_array` in:
* `add_magic_quotes()`
* `wp_array_slice_assoc()`
* `_wp_array_get()`
* `_wp_array_set()`
* Renames the `$function` parameter to `$function_name` in:
* `_deprecated_function()`
* `_deprecated_argument()`
* `_doing_it_wrong()`
* Renames the `$class` parameter to `$class_name` in `_deprecated_constructor()`.
* Renames the `$default` parameter to `$default_value` in `apache_mod_loaded()`.
* Renames the `$var` parameter to `$value` in `wp_validate_boolean()`.
* Amends the `$input` parameter in `wp_parse_str()` for consistency.
Follow-up to [52946], [52996], [52997], [52998], [53003], [53014], [53029], [53039], [53116], [53117], [53137], [53174], [53184], [53185], [53192], [53193], [53198], [53203], [53207], [53215], [53216], [53220], [53230], [53232], [53236], [53239], [53240], [53242], [53243], [53245], [53246], [53257], [53269], [53270], [53271], [53272], [53273], [53274], [53275], [53276], [53277], [53281], [53283], [53284], [53285], [53287], [53364], [53365], [54927].
Props jrf, aristath, poena, justinahinon, SergeyBiryukov.
See #56788.
Built from https://develop.svn.wordpress.org/trunk@54929
git-svn-id: http://core.svn.wordpress.org/trunk@54481 1a063a9b-81f0-0310-95a4-ce76da25c4cd
2022-12-03 10:07:14 -05:00
* @ param array $input_list An array of objects to filter .
* @ param array $args Optional . An array of key => value arguments to match
* against each object . Default empty array .
* @ param string $operator Optional . The logical operation to perform . 'AND' means
* all elements from the array must match . 'OR' means only
* one element needs to match . 'NOT' means no elements may
* match . Default 'AND' .
2014-06-30 21:44:15 -04:00
* @ return array Array of found values .
2010-10-02 14:48:51 -04:00
*/
Code Modernization: Rename parameters that use reserved keywords in `wp-includes/functions.php`.
While using reserved PHP keywords as parameter name labels is allowed, in the context of function calls using named parameters in PHP 8.0+, this will easily lead to confusion. To avoid that, it is recommended not to use reserved keywords as function parameter names.
This commit:
* Renames the `$echo` parameter to `$display` in:
* `wp_nonce_field()`
* `wp_referer_field()`
* `wp_original_referer_field()`
* Renames the `$string` parameter to `$input_string` in
* `_wp_json_convert_string()`
* `_wp_to_kebab_case()`
* Renames the `$list` parameter to `$input_list` in:
* `wp_parse_list()`
* `wp_parse_id_list()`
* `wp_parse_slug_list()`
* `wp_filter_object_list()`
* `wp_list_filter()`
* `wp_list_pluck()`
* `wp_list_sort()`
* Renames the `$array` parameter to `$input_array` in:
* `add_magic_quotes()`
* `wp_array_slice_assoc()`
* `_wp_array_get()`
* `_wp_array_set()`
* Renames the `$function` parameter to `$function_name` in:
* `_deprecated_function()`
* `_deprecated_argument()`
* `_doing_it_wrong()`
* Renames the `$class` parameter to `$class_name` in `_deprecated_constructor()`.
* Renames the `$default` parameter to `$default_value` in `apache_mod_loaded()`.
* Renames the `$var` parameter to `$value` in `wp_validate_boolean()`.
* Amends the `$input` parameter in `wp_parse_str()` for consistency.
Follow-up to [52946], [52996], [52997], [52998], [53003], [53014], [53029], [53039], [53116], [53117], [53137], [53174], [53184], [53185], [53192], [53193], [53198], [53203], [53207], [53215], [53216], [53220], [53230], [53232], [53236], [53239], [53240], [53242], [53243], [53245], [53246], [53257], [53269], [53270], [53271], [53272], [53273], [53274], [53275], [53276], [53277], [53281], [53283], [53284], [53285], [53287], [53364], [53365], [54927].
Props jrf, aristath, poena, justinahinon, SergeyBiryukov.
See #56788.
Built from https://develop.svn.wordpress.org/trunk@54929
git-svn-id: http://core.svn.wordpress.org/trunk@54481 1a063a9b-81f0-0310-95a4-ce76da25c4cd
2022-12-03 10:07:14 -05:00
function wp_list_filter ( $input_list , $args = array (), $operator = 'AND' ) {
return wp_filter_object_list ( $input_list , $args , $operator );
2010-04-16 10:08:58 -04:00
}
2010-10-02 14:48:51 -04:00
/**
2021-12-29 12:28:00 -05:00
* Plucks a certain field out of each object or array in an array .
2010-10-02 14:48:51 -04:00
*
2014-06-29 17:26:17 -04:00
* This has the same functionality and prototype of
* array_column () ( PHP 5.5 ) but also supports objects .
*
2010-10-02 14:48:51 -04:00
* @ since 3.1 . 0
2014-06-30 21:44:15 -04:00
* @ since 4.0 . 0 $index_key parameter added .
2018-02-09 11:55:31 -05:00
* @ since 4.7 . 0 Uses `WP_List_Util` class .
2010-10-02 14:48:51 -04:00
*
Code Modernization: Rename parameters that use reserved keywords in `wp-includes/functions.php`.
While using reserved PHP keywords as parameter name labels is allowed, in the context of function calls using named parameters in PHP 8.0+, this will easily lead to confusion. To avoid that, it is recommended not to use reserved keywords as function parameter names.
This commit:
* Renames the `$echo` parameter to `$display` in:
* `wp_nonce_field()`
* `wp_referer_field()`
* `wp_original_referer_field()`
* Renames the `$string` parameter to `$input_string` in
* `_wp_json_convert_string()`
* `_wp_to_kebab_case()`
* Renames the `$list` parameter to `$input_list` in:
* `wp_parse_list()`
* `wp_parse_id_list()`
* `wp_parse_slug_list()`
* `wp_filter_object_list()`
* `wp_list_filter()`
* `wp_list_pluck()`
* `wp_list_sort()`
* Renames the `$array` parameter to `$input_array` in:
* `add_magic_quotes()`
* `wp_array_slice_assoc()`
* `_wp_array_get()`
* `_wp_array_set()`
* Renames the `$function` parameter to `$function_name` in:
* `_deprecated_function()`
* `_deprecated_argument()`
* `_doing_it_wrong()`
* Renames the `$class` parameter to `$class_name` in `_deprecated_constructor()`.
* Renames the `$default` parameter to `$default_value` in `apache_mod_loaded()`.
* Renames the `$var` parameter to `$value` in `wp_validate_boolean()`.
* Amends the `$input` parameter in `wp_parse_str()` for consistency.
Follow-up to [52946], [52996], [52997], [52998], [53003], [53014], [53029], [53039], [53116], [53117], [53137], [53174], [53184], [53185], [53192], [53193], [53198], [53203], [53207], [53215], [53216], [53220], [53230], [53232], [53236], [53239], [53240], [53242], [53243], [53245], [53246], [53257], [53269], [53270], [53271], [53272], [53273], [53274], [53275], [53276], [53277], [53281], [53283], [53284], [53285], [53287], [53364], [53365], [54927].
Props jrf, aristath, poena, justinahinon, SergeyBiryukov.
See #56788.
Built from https://develop.svn.wordpress.org/trunk@54929
git-svn-id: http://core.svn.wordpress.org/trunk@54481 1a063a9b-81f0-0310-95a4-ce76da25c4cd
2022-12-03 10:07:14 -05:00
* @ param array $input_list List of objects or arrays .
* @ param int | string $field Field from the object to place instead of the entire object .
* @ param int | string $index_key Optional . Field from the object to use as keys for the new array .
* Default null .
2015-02-13 11:52:27 -05:00
* @ return array Array of found values . If `$index_key` is set , an array of found values with keys
* corresponding to `$index_key` . If `$index_key` is null , array keys from the original
Code Modernization: Rename parameters that use reserved keywords in `wp-includes/functions.php`.
While using reserved PHP keywords as parameter name labels is allowed, in the context of function calls using named parameters in PHP 8.0+, this will easily lead to confusion. To avoid that, it is recommended not to use reserved keywords as function parameter names.
This commit:
* Renames the `$echo` parameter to `$display` in:
* `wp_nonce_field()`
* `wp_referer_field()`
* `wp_original_referer_field()`
* Renames the `$string` parameter to `$input_string` in
* `_wp_json_convert_string()`
* `_wp_to_kebab_case()`
* Renames the `$list` parameter to `$input_list` in:
* `wp_parse_list()`
* `wp_parse_id_list()`
* `wp_parse_slug_list()`
* `wp_filter_object_list()`
* `wp_list_filter()`
* `wp_list_pluck()`
* `wp_list_sort()`
* Renames the `$array` parameter to `$input_array` in:
* `add_magic_quotes()`
* `wp_array_slice_assoc()`
* `_wp_array_get()`
* `_wp_array_set()`
* Renames the `$function` parameter to `$function_name` in:
* `_deprecated_function()`
* `_deprecated_argument()`
* `_doing_it_wrong()`
* Renames the `$class` parameter to `$class_name` in `_deprecated_constructor()`.
* Renames the `$default` parameter to `$default_value` in `apache_mod_loaded()`.
* Renames the `$var` parameter to `$value` in `wp_validate_boolean()`.
* Amends the `$input` parameter in `wp_parse_str()` for consistency.
Follow-up to [52946], [52996], [52997], [52998], [53003], [53014], [53029], [53039], [53116], [53117], [53137], [53174], [53184], [53185], [53192], [53193], [53198], [53203], [53207], [53215], [53216], [53220], [53230], [53232], [53236], [53239], [53240], [53242], [53243], [53245], [53246], [53257], [53269], [53270], [53271], [53272], [53273], [53274], [53275], [53276], [53277], [53281], [53283], [53284], [53285], [53287], [53364], [53365], [54927].
Props jrf, aristath, poena, justinahinon, SergeyBiryukov.
See #56788.
Built from https://develop.svn.wordpress.org/trunk@54929
git-svn-id: http://core.svn.wordpress.org/trunk@54481 1a063a9b-81f0-0310-95a4-ce76da25c4cd
2022-12-03 10:07:14 -05:00
* `$input_list` will be preserved in the results .
2010-10-02 14:48:51 -04:00
*/
Code Modernization: Rename parameters that use reserved keywords in `wp-includes/functions.php`.
While using reserved PHP keywords as parameter name labels is allowed, in the context of function calls using named parameters in PHP 8.0+, this will easily lead to confusion. To avoid that, it is recommended not to use reserved keywords as function parameter names.
This commit:
* Renames the `$echo` parameter to `$display` in:
* `wp_nonce_field()`
* `wp_referer_field()`
* `wp_original_referer_field()`
* Renames the `$string` parameter to `$input_string` in
* `_wp_json_convert_string()`
* `_wp_to_kebab_case()`
* Renames the `$list` parameter to `$input_list` in:
* `wp_parse_list()`
* `wp_parse_id_list()`
* `wp_parse_slug_list()`
* `wp_filter_object_list()`
* `wp_list_filter()`
* `wp_list_pluck()`
* `wp_list_sort()`
* Renames the `$array` parameter to `$input_array` in:
* `add_magic_quotes()`
* `wp_array_slice_assoc()`
* `_wp_array_get()`
* `_wp_array_set()`
* Renames the `$function` parameter to `$function_name` in:
* `_deprecated_function()`
* `_deprecated_argument()`
* `_doing_it_wrong()`
* Renames the `$class` parameter to `$class_name` in `_deprecated_constructor()`.
* Renames the `$default` parameter to `$default_value` in `apache_mod_loaded()`.
* Renames the `$var` parameter to `$value` in `wp_validate_boolean()`.
* Amends the `$input` parameter in `wp_parse_str()` for consistency.
Follow-up to [52946], [52996], [52997], [52998], [53003], [53014], [53029], [53039], [53116], [53117], [53137], [53174], [53184], [53185], [53192], [53193], [53198], [53203], [53207], [53215], [53216], [53220], [53230], [53232], [53236], [53239], [53240], [53242], [53243], [53245], [53246], [53257], [53269], [53270], [53271], [53272], [53273], [53274], [53275], [53276], [53277], [53281], [53283], [53284], [53285], [53287], [53364], [53365], [54927].
Props jrf, aristath, poena, justinahinon, SergeyBiryukov.
See #56788.
Built from https://develop.svn.wordpress.org/trunk@54929
git-svn-id: http://core.svn.wordpress.org/trunk@54481 1a063a9b-81f0-0310-95a4-ce76da25c4cd
2022-12-03 10:07:14 -05:00
function wp_list_pluck ( $input_list , $field , $index_key = null ) {
if ( ! is_array ( $input_list ) ) {
2022-04-01 01:56:06 -04:00
return array ();
}
Code Modernization: Rename parameters that use reserved keywords in `wp-includes/functions.php`.
While using reserved PHP keywords as parameter name labels is allowed, in the context of function calls using named parameters in PHP 8.0+, this will easily lead to confusion. To avoid that, it is recommended not to use reserved keywords as function parameter names.
This commit:
* Renames the `$echo` parameter to `$display` in:
* `wp_nonce_field()`
* `wp_referer_field()`
* `wp_original_referer_field()`
* Renames the `$string` parameter to `$input_string` in
* `_wp_json_convert_string()`
* `_wp_to_kebab_case()`
* Renames the `$list` parameter to `$input_list` in:
* `wp_parse_list()`
* `wp_parse_id_list()`
* `wp_parse_slug_list()`
* `wp_filter_object_list()`
* `wp_list_filter()`
* `wp_list_pluck()`
* `wp_list_sort()`
* Renames the `$array` parameter to `$input_array` in:
* `add_magic_quotes()`
* `wp_array_slice_assoc()`
* `_wp_array_get()`
* `_wp_array_set()`
* Renames the `$function` parameter to `$function_name` in:
* `_deprecated_function()`
* `_deprecated_argument()`
* `_doing_it_wrong()`
* Renames the `$class` parameter to `$class_name` in `_deprecated_constructor()`.
* Renames the `$default` parameter to `$default_value` in `apache_mod_loaded()`.
* Renames the `$var` parameter to `$value` in `wp_validate_boolean()`.
* Amends the `$input` parameter in `wp_parse_str()` for consistency.
Follow-up to [52946], [52996], [52997], [52998], [53003], [53014], [53029], [53039], [53116], [53117], [53137], [53174], [53184], [53185], [53192], [53193], [53198], [53203], [53207], [53215], [53216], [53220], [53230], [53232], [53236], [53239], [53240], [53242], [53243], [53245], [53246], [53257], [53269], [53270], [53271], [53272], [53273], [53274], [53275], [53276], [53277], [53281], [53283], [53284], [53285], [53287], [53364], [53365], [54927].
Props jrf, aristath, poena, justinahinon, SergeyBiryukov.
See #56788.
Built from https://develop.svn.wordpress.org/trunk@54929
git-svn-id: http://core.svn.wordpress.org/trunk@54481 1a063a9b-81f0-0310-95a4-ce76da25c4cd
2022-12-03 10:07:14 -05:00
$util = new WP_List_Util ( $input_list );
2021-05-28 14:04:57 -04:00
2016-10-25 17:26:32 -04:00
return $util -> pluck ( $field , $index_key );
}
2010-10-02 14:48:51 -04:00
2016-10-25 17:26:32 -04:00
/**
2021-12-29 12:28:00 -05:00
* Sorts an array of objects or arrays based on one or more orderby arguments .
2016-10-25 17:26:32 -04:00
*
* @ since 4.7 . 0
*
Code Modernization: Rename parameters that use reserved keywords in `wp-includes/functions.php`.
While using reserved PHP keywords as parameter name labels is allowed, in the context of function calls using named parameters in PHP 8.0+, this will easily lead to confusion. To avoid that, it is recommended not to use reserved keywords as function parameter names.
This commit:
* Renames the `$echo` parameter to `$display` in:
* `wp_nonce_field()`
* `wp_referer_field()`
* `wp_original_referer_field()`
* Renames the `$string` parameter to `$input_string` in
* `_wp_json_convert_string()`
* `_wp_to_kebab_case()`
* Renames the `$list` parameter to `$input_list` in:
* `wp_parse_list()`
* `wp_parse_id_list()`
* `wp_parse_slug_list()`
* `wp_filter_object_list()`
* `wp_list_filter()`
* `wp_list_pluck()`
* `wp_list_sort()`
* Renames the `$array` parameter to `$input_array` in:
* `add_magic_quotes()`
* `wp_array_slice_assoc()`
* `_wp_array_get()`
* `_wp_array_set()`
* Renames the `$function` parameter to `$function_name` in:
* `_deprecated_function()`
* `_deprecated_argument()`
* `_doing_it_wrong()`
* Renames the `$class` parameter to `$class_name` in `_deprecated_constructor()`.
* Renames the `$default` parameter to `$default_value` in `apache_mod_loaded()`.
* Renames the `$var` parameter to `$value` in `wp_validate_boolean()`.
* Amends the `$input` parameter in `wp_parse_str()` for consistency.
Follow-up to [52946], [52996], [52997], [52998], [53003], [53014], [53029], [53039], [53116], [53117], [53137], [53174], [53184], [53185], [53192], [53193], [53198], [53203], [53207], [53215], [53216], [53220], [53230], [53232], [53236], [53239], [53240], [53242], [53243], [53245], [53246], [53257], [53269], [53270], [53271], [53272], [53273], [53274], [53275], [53276], [53277], [53281], [53283], [53284], [53285], [53287], [53364], [53365], [54927].
Props jrf, aristath, poena, justinahinon, SergeyBiryukov.
See #56788.
Built from https://develop.svn.wordpress.org/trunk@54929
git-svn-id: http://core.svn.wordpress.org/trunk@54481 1a063a9b-81f0-0310-95a4-ce76da25c4cd
2022-12-03 10:07:14 -05:00
* @ param array $input_list An array of objects or arrays to sort .
2016-10-25 17:26:32 -04:00
* @ param string | array $orderby Optional . Either the field name to order by or an array
Docs: Update various DocBlocks and inline comments per the documentation standards.
Includes minor formatting edits for consistency.
Follow-up to [53/tests], [12179], [12946], [35288], [37884], [38810], [38928], [46596], [48131], [52955], [53548], [53813], [53873], [54118], [54316], [54420], [54421], [54803].
See #56792.
Built from https://develop.svn.wordpress.org/trunk@54855
git-svn-id: http://core.svn.wordpress.org/trunk@54407 1a063a9b-81f0-0310-95a4-ce76da25c4cd
2022-11-17 13:15:19 -05:00
* of multiple orderby fields as `$orderby => $order` .
* Default empty array .
* @ param string $order Optional . Either 'ASC' or 'DESC' . Only used if `$orderby`
* is a string . Default 'ASC' .
2016-10-25 17:26:32 -04:00
* @ param bool $preserve_keys Optional . Whether to preserve keys . Default false .
* @ return array The sorted array .
*/
Code Modernization: Rename parameters that use reserved keywords in `wp-includes/functions.php`.
While using reserved PHP keywords as parameter name labels is allowed, in the context of function calls using named parameters in PHP 8.0+, this will easily lead to confusion. To avoid that, it is recommended not to use reserved keywords as function parameter names.
This commit:
* Renames the `$echo` parameter to `$display` in:
* `wp_nonce_field()`
* `wp_referer_field()`
* `wp_original_referer_field()`
* Renames the `$string` parameter to `$input_string` in
* `_wp_json_convert_string()`
* `_wp_to_kebab_case()`
* Renames the `$list` parameter to `$input_list` in:
* `wp_parse_list()`
* `wp_parse_id_list()`
* `wp_parse_slug_list()`
* `wp_filter_object_list()`
* `wp_list_filter()`
* `wp_list_pluck()`
* `wp_list_sort()`
* Renames the `$array` parameter to `$input_array` in:
* `add_magic_quotes()`
* `wp_array_slice_assoc()`
* `_wp_array_get()`
* `_wp_array_set()`
* Renames the `$function` parameter to `$function_name` in:
* `_deprecated_function()`
* `_deprecated_argument()`
* `_doing_it_wrong()`
* Renames the `$class` parameter to `$class_name` in `_deprecated_constructor()`.
* Renames the `$default` parameter to `$default_value` in `apache_mod_loaded()`.
* Renames the `$var` parameter to `$value` in `wp_validate_boolean()`.
* Amends the `$input` parameter in `wp_parse_str()` for consistency.
Follow-up to [52946], [52996], [52997], [52998], [53003], [53014], [53029], [53039], [53116], [53117], [53137], [53174], [53184], [53185], [53192], [53193], [53198], [53203], [53207], [53215], [53216], [53220], [53230], [53232], [53236], [53239], [53240], [53242], [53243], [53245], [53246], [53257], [53269], [53270], [53271], [53272], [53273], [53274], [53275], [53276], [53277], [53281], [53283], [53284], [53285], [53287], [53364], [53365], [54927].
Props jrf, aristath, poena, justinahinon, SergeyBiryukov.
See #56788.
Built from https://develop.svn.wordpress.org/trunk@54929
git-svn-id: http://core.svn.wordpress.org/trunk@54481 1a063a9b-81f0-0310-95a4-ce76da25c4cd
2022-12-03 10:07:14 -05:00
function wp_list_sort ( $input_list , $orderby = array (), $order = 'ASC' , $preserve_keys = false ) {
if ( ! is_array ( $input_list ) ) {
2016-10-25 17:26:32 -04:00
return array ();
2014-06-29 17:26:17 -04:00
}
Code Modernization: Rename parameters that use reserved keywords in `wp-includes/functions.php`.
While using reserved PHP keywords as parameter name labels is allowed, in the context of function calls using named parameters in PHP 8.0+, this will easily lead to confusion. To avoid that, it is recommended not to use reserved keywords as function parameter names.
This commit:
* Renames the `$echo` parameter to `$display` in:
* `wp_nonce_field()`
* `wp_referer_field()`
* `wp_original_referer_field()`
* Renames the `$string` parameter to `$input_string` in
* `_wp_json_convert_string()`
* `_wp_to_kebab_case()`
* Renames the `$list` parameter to `$input_list` in:
* `wp_parse_list()`
* `wp_parse_id_list()`
* `wp_parse_slug_list()`
* `wp_filter_object_list()`
* `wp_list_filter()`
* `wp_list_pluck()`
* `wp_list_sort()`
* Renames the `$array` parameter to `$input_array` in:
* `add_magic_quotes()`
* `wp_array_slice_assoc()`
* `_wp_array_get()`
* `_wp_array_set()`
* Renames the `$function` parameter to `$function_name` in:
* `_deprecated_function()`
* `_deprecated_argument()`
* `_doing_it_wrong()`
* Renames the `$class` parameter to `$class_name` in `_deprecated_constructor()`.
* Renames the `$default` parameter to `$default_value` in `apache_mod_loaded()`.
* Renames the `$var` parameter to `$value` in `wp_validate_boolean()`.
* Amends the `$input` parameter in `wp_parse_str()` for consistency.
Follow-up to [52946], [52996], [52997], [52998], [53003], [53014], [53029], [53039], [53116], [53117], [53137], [53174], [53184], [53185], [53192], [53193], [53198], [53203], [53207], [53215], [53216], [53220], [53230], [53232], [53236], [53239], [53240], [53242], [53243], [53245], [53246], [53257], [53269], [53270], [53271], [53272], [53273], [53274], [53275], [53276], [53277], [53281], [53283], [53284], [53285], [53287], [53364], [53365], [54927].
Props jrf, aristath, poena, justinahinon, SergeyBiryukov.
See #56788.
Built from https://develop.svn.wordpress.org/trunk@54929
git-svn-id: http://core.svn.wordpress.org/trunk@54481 1a063a9b-81f0-0310-95a4-ce76da25c4cd
2022-12-03 10:07:14 -05:00
$util = new WP_List_Util ( $input_list );
2021-05-28 14:04:57 -04:00
2016-10-25 17:26:32 -04:00
return $util -> sort ( $orderby , $order , $preserve_keys );
2010-10-02 14:48:51 -04:00
}
2008-06-15 05:38:32 -04:00
/**
* Determines if Widgets library should be loaded .
*
2014-06-30 21:44:15 -04:00
* Checks to make sure that the widgets library hasn ' t already been loaded .
* If it hasn ' t , then it will load the widgets library and run an action hook .
2008-06-15 05:38:32 -04:00
*
* @ since 2.2 . 0
*/
2007-04-30 21:58:18 -04:00
function wp_maybe_load_widgets () {
2014-04-13 20:20:14 -04:00
/**
2016-05-22 14:36:27 -04:00
* Filters whether to load the Widgets library .
2014-04-13 20:20:14 -04:00
*
2020-06-26 14:49:09 -04:00
* Returning a falsey value from the filter will effectively short - circuit
2014-06-30 21:44:15 -04:00
* the Widgets library from loading .
*
2014-04-13 20:20:14 -04:00
* @ since 2.8 . 0
*
* @ param bool $wp_maybe_load_widgets Whether to load the Widgets library .
* Default true .
*/
if ( ! apply_filters ( 'load_default_widgets' , true ) ) {
2009-03-16 18:02:40 -04:00
return ;
2014-04-13 20:20:14 -04:00
}
2014-06-30 21:44:15 -04:00
2020-02-06 01:33:11 -05:00
require_once ABSPATH . WPINC . '/default-widgets.php' ;
2014-06-30 21:44:15 -04:00
2009-03-16 18:02:40 -04:00
add_action ( '_admin_menu' , 'wp_widgets_add_menu' );
2007-04-30 21:13:06 -04:00
}
2008-06-15 05:38:32 -04:00
/**
2022-08-12 05:53:11 -04:00
* Appends the Widgets menu to the themes main menu .
2008-06-15 05:38:32 -04:00
*
* @ since 2.2 . 0
2022-03-29 11:59:22 -04:00
* @ since 5.9 . 3 Don ' t specify menu order when the active theme is a block theme .
2015-05-25 12:11:25 -04:00
*
* @ global array $submenu
2008-06-15 05:38:32 -04:00
*/
2007-05-06 16:36:11 -04:00
function wp_widgets_add_menu () {
2007-05-02 20:52:14 -04:00
global $submenu ;
2012-09-11 22:16:46 -04:00
2017-11-30 18:11:00 -05:00
if ( ! current_theme_supports ( 'widgets' ) ) {
2012-09-11 22:16:46 -04:00
return ;
2017-11-30 18:11:00 -05:00
}
2012-09-11 22:16:46 -04:00
2022-03-29 11:59:22 -04:00
$menu_name = __ ( 'Widgets' );
2022-09-15 08:20:09 -04:00
if ( wp_is_block_theme () || current_theme_supports ( 'block-template-parts' ) ) {
2022-03-29 11:59:22 -04:00
$submenu [ 'themes.php' ][] = array ( $menu_name , 'edit_theme_options' , 'widgets.php' );
} else {
$submenu [ 'themes.php' ][ 7 ] = array ( $menu_name , 'edit_theme_options' , 'widgets.php' );
}
2007-10-11 01:46:57 -04:00
ksort ( $submenu [ 'themes.php' ], SORT_NUMERIC );
2007-05-02 20:52:14 -04:00
}
2008-06-15 05:38:32 -04:00
/**
2022-08-12 05:53:11 -04:00
* Flushes all output buffers for PHP 5.2 .
2008-06-15 05:38:32 -04:00
*
2014-06-30 21:44:15 -04:00
* Make sure all output buffers are flushed before our singletons are destroyed .
2008-06-15 05:38:32 -04:00
*
* @ since 2.2 . 0
2008-06-15 15:11:15 -04:00
*/
2007-10-11 01:46:57 -04:00
function wp_ob_end_flush_all () {
2009-05-24 19:47:49 -04:00
$levels = ob_get_level ();
2017-11-30 18:11:00 -05:00
for ( $i = 0 ; $i < $levels ; $i ++ ) {
2009-05-24 19:47:49 -04:00
ob_end_flush ();
2017-11-30 18:11:00 -05:00
}
2007-05-12 18:06:31 -04:00
}
2008-06-15 05:38:32 -04:00
/**
2022-08-12 05:53:11 -04:00
* Loads custom DB error or display WordPress DB error .
2008-06-15 05:38:32 -04:00
*
* If a file exists in the wp - content directory named db - error . php , then it will
* be loaded instead of displaying the WordPress DB error . If it is not found ,
* then the WordPress DB error will be displayed instead .
*
* The WordPress DB error sets the HTTP status header to 500 to try to prevent
* search engines from caching the message . Custom DB messages should do the
* same .
*
2013-05-09 21:39:30 -04:00
* This function was backported to WordPress 2.3 . 2 , but originally was added
* in WordPress 2.5 . 0.
2008-08-10 12:45:50 -04:00
*
* @ since 2.3 . 2
2014-06-30 21:44:15 -04:00
*
2014-10-31 13:56:22 -04:00
* @ global wpdb $wpdb WordPress database abstraction object .
2008-06-15 05:38:32 -04:00
*/
2007-12-20 21:53:57 -05:00
function dead_db () {
global $wpdb ;
2014-01-29 00:28:12 -05:00
wp_load_translations_early ();
2007-12-20 21:53:57 -05:00
// Load custom DB error template, if present.
2008-05-27 13:55:24 -04:00
if ( file_exists ( WP_CONTENT_DIR . '/db-error.php' ) ) {
2020-02-06 01:33:11 -05:00
require_once WP_CONTENT_DIR . '/db-error.php' ;
2007-12-20 21:53:57 -05:00
die ();
}
// If installing or in the admin, provide the verbose message.
2017-11-30 18:11:00 -05:00
if ( wp_installing () || defined ( 'WP_ADMIN' ) ) {
wp_die ( $wpdb -> error );
}
2007-12-20 21:53:57 -05:00
// Otherwise, be terse.
2019-03-11 07:31:50 -04:00
wp_die ( '<h1>' . __ ( 'Error establishing a database connection' ) . '</h1>' , __ ( 'Database Error' ) );
2007-12-20 21:53:57 -05:00
}
2007-10-11 01:46:57 -04:00
2007-10-10 18:11:18 -04:00
/**
2022-08-12 05:53:11 -04:00
* Converts a value to non - negative integer .
2008-06-15 05:38:32 -04:00
*
2008-08-10 12:45:50 -04:00
* @ since 2.5 . 0
2008-08-09 00:51:51 -04:00
*
2014-07-07 02:19:14 -04:00
* @ param mixed $maybeint Data you wish to have converted to a non - negative integer .
* @ return int A non - negative integer .
2007-10-10 18:11:18 -04:00
*/
2014-06-26 14:45:14 -04:00
function absint ( $maybeint ) {
2020-10-08 17:15:13 -04:00
return abs ( ( int ) $maybeint );
2007-10-10 18:11:18 -04:00
}
2007-12-28 16:17:42 -05:00
/**
2022-08-12 05:53:11 -04:00
* Marks a function as deprecated and inform when it has been used .
2007-12-28 16:17:42 -05:00
*
2022-09-23 12:20:09 -04:00
* There is a hook { @ see 'deprecated_function_run' } that will be called that can be used
2008-06-15 05:38:32 -04:00
* to get the backtrace up to what file and function called the deprecated
* function .
2007-12-28 16:17:42 -05:00
*
2016-05-23 15:01:27 -04:00
* The current behavior is to trigger a user error if `WP_DEBUG` is true .
2008-02-05 01:47:27 -05:00
*
2010-12-15 07:09:53 -05:00
* This function is to be used in every function that is deprecated .
2007-12-28 16:17:42 -05:00
*
2008-08-10 12:45:50 -04:00
* @ since 2.5 . 0
2019-10-27 10:21:03 -04:00
* @ since 5.4 . 0 This function is no longer marked as " private " .
2019-10-31 20:41:01 -04:00
* @ since 5.4 . 0 The error type is now classified as E_USER_DEPRECATED ( used to default to E_USER_NOTICE ) .
2007-12-28 16:17:42 -05:00
*
Code Modernization: Rename parameters that use reserved keywords in `wp-includes/functions.php`.
While using reserved PHP keywords as parameter name labels is allowed, in the context of function calls using named parameters in PHP 8.0+, this will easily lead to confusion. To avoid that, it is recommended not to use reserved keywords as function parameter names.
This commit:
* Renames the `$echo` parameter to `$display` in:
* `wp_nonce_field()`
* `wp_referer_field()`
* `wp_original_referer_field()`
* Renames the `$string` parameter to `$input_string` in
* `_wp_json_convert_string()`
* `_wp_to_kebab_case()`
* Renames the `$list` parameter to `$input_list` in:
* `wp_parse_list()`
* `wp_parse_id_list()`
* `wp_parse_slug_list()`
* `wp_filter_object_list()`
* `wp_list_filter()`
* `wp_list_pluck()`
* `wp_list_sort()`
* Renames the `$array` parameter to `$input_array` in:
* `add_magic_quotes()`
* `wp_array_slice_assoc()`
* `_wp_array_get()`
* `_wp_array_set()`
* Renames the `$function` parameter to `$function_name` in:
* `_deprecated_function()`
* `_deprecated_argument()`
* `_doing_it_wrong()`
* Renames the `$class` parameter to `$class_name` in `_deprecated_constructor()`.
* Renames the `$default` parameter to `$default_value` in `apache_mod_loaded()`.
* Renames the `$var` parameter to `$value` in `wp_validate_boolean()`.
* Amends the `$input` parameter in `wp_parse_str()` for consistency.
Follow-up to [52946], [52996], [52997], [52998], [53003], [53014], [53029], [53039], [53116], [53117], [53137], [53174], [53184], [53185], [53192], [53193], [53198], [53203], [53207], [53215], [53216], [53220], [53230], [53232], [53236], [53239], [53240], [53242], [53243], [53245], [53246], [53257], [53269], [53270], [53271], [53272], [53273], [53274], [53275], [53276], [53277], [53281], [53283], [53284], [53285], [53287], [53364], [53365], [54927].
Props jrf, aristath, poena, justinahinon, SergeyBiryukov.
See #56788.
Built from https://develop.svn.wordpress.org/trunk@54929
git-svn-id: http://core.svn.wordpress.org/trunk@54481 1a063a9b-81f0-0310-95a4-ce76da25c4cd
2022-12-03 10:07:14 -05:00
* @ param string $function_name The function that was called .
* @ param string $version The version of WordPress that deprecated the function .
2023-02-21 11:39:19 -05:00
* @ param string $replacement Optional . The function that should have been called . Default empty string .
2007-12-28 16:17:42 -05:00
*/
Code Modernization: Rename parameters that use reserved keywords in `wp-includes/functions.php`.
While using reserved PHP keywords as parameter name labels is allowed, in the context of function calls using named parameters in PHP 8.0+, this will easily lead to confusion. To avoid that, it is recommended not to use reserved keywords as function parameter names.
This commit:
* Renames the `$echo` parameter to `$display` in:
* `wp_nonce_field()`
* `wp_referer_field()`
* `wp_original_referer_field()`
* Renames the `$string` parameter to `$input_string` in
* `_wp_json_convert_string()`
* `_wp_to_kebab_case()`
* Renames the `$list` parameter to `$input_list` in:
* `wp_parse_list()`
* `wp_parse_id_list()`
* `wp_parse_slug_list()`
* `wp_filter_object_list()`
* `wp_list_filter()`
* `wp_list_pluck()`
* `wp_list_sort()`
* Renames the `$array` parameter to `$input_array` in:
* `add_magic_quotes()`
* `wp_array_slice_assoc()`
* `_wp_array_get()`
* `_wp_array_set()`
* Renames the `$function` parameter to `$function_name` in:
* `_deprecated_function()`
* `_deprecated_argument()`
* `_doing_it_wrong()`
* Renames the `$class` parameter to `$class_name` in `_deprecated_constructor()`.
* Renames the `$default` parameter to `$default_value` in `apache_mod_loaded()`.
* Renames the `$var` parameter to `$value` in `wp_validate_boolean()`.
* Amends the `$input` parameter in `wp_parse_str()` for consistency.
Follow-up to [52946], [52996], [52997], [52998], [53003], [53014], [53029], [53039], [53116], [53117], [53137], [53174], [53184], [53185], [53192], [53193], [53198], [53203], [53207], [53215], [53216], [53220], [53230], [53232], [53236], [53239], [53240], [53242], [53243], [53245], [53246], [53257], [53269], [53270], [53271], [53272], [53273], [53274], [53275], [53276], [53277], [53281], [53283], [53284], [53285], [53287], [53364], [53365], [54927].
Props jrf, aristath, poena, justinahinon, SergeyBiryukov.
See #56788.
Built from https://develop.svn.wordpress.org/trunk@54929
git-svn-id: http://core.svn.wordpress.org/trunk@54481 1a063a9b-81f0-0310-95a4-ce76da25c4cd
2022-12-03 10:07:14 -05:00
function _deprecated_function ( $function_name , $version , $replacement = '' ) {
2007-12-28 16:17:42 -05:00
2014-04-13 20:20:14 -04:00
/**
* Fires when a deprecated function is called .
*
* @ since 2.5 . 0
*
Code Modernization: Rename parameters that use reserved keywords in `wp-includes/functions.php`.
While using reserved PHP keywords as parameter name labels is allowed, in the context of function calls using named parameters in PHP 8.0+, this will easily lead to confusion. To avoid that, it is recommended not to use reserved keywords as function parameter names.
This commit:
* Renames the `$echo` parameter to `$display` in:
* `wp_nonce_field()`
* `wp_referer_field()`
* `wp_original_referer_field()`
* Renames the `$string` parameter to `$input_string` in
* `_wp_json_convert_string()`
* `_wp_to_kebab_case()`
* Renames the `$list` parameter to `$input_list` in:
* `wp_parse_list()`
* `wp_parse_id_list()`
* `wp_parse_slug_list()`
* `wp_filter_object_list()`
* `wp_list_filter()`
* `wp_list_pluck()`
* `wp_list_sort()`
* Renames the `$array` parameter to `$input_array` in:
* `add_magic_quotes()`
* `wp_array_slice_assoc()`
* `_wp_array_get()`
* `_wp_array_set()`
* Renames the `$function` parameter to `$function_name` in:
* `_deprecated_function()`
* `_deprecated_argument()`
* `_doing_it_wrong()`
* Renames the `$class` parameter to `$class_name` in `_deprecated_constructor()`.
* Renames the `$default` parameter to `$default_value` in `apache_mod_loaded()`.
* Renames the `$var` parameter to `$value` in `wp_validate_boolean()`.
* Amends the `$input` parameter in `wp_parse_str()` for consistency.
Follow-up to [52946], [52996], [52997], [52998], [53003], [53014], [53029], [53039], [53116], [53117], [53137], [53174], [53184], [53185], [53192], [53193], [53198], [53203], [53207], [53215], [53216], [53220], [53230], [53232], [53236], [53239], [53240], [53242], [53243], [53245], [53246], [53257], [53269], [53270], [53271], [53272], [53273], [53274], [53275], [53276], [53277], [53281], [53283], [53284], [53285], [53287], [53364], [53365], [54927].
Props jrf, aristath, poena, justinahinon, SergeyBiryukov.
See #56788.
Built from https://develop.svn.wordpress.org/trunk@54929
git-svn-id: http://core.svn.wordpress.org/trunk@54481 1a063a9b-81f0-0310-95a4-ce76da25c4cd
2022-12-03 10:07:14 -05:00
* @ param string $function_name The function that was called .
* @ param string $replacement The function that should have been called .
* @ param string $version The version of WordPress that deprecated the function .
2014-04-13 20:20:14 -04:00
*/
Code Modernization: Rename parameters that use reserved keywords in `wp-includes/functions.php`.
While using reserved PHP keywords as parameter name labels is allowed, in the context of function calls using named parameters in PHP 8.0+, this will easily lead to confusion. To avoid that, it is recommended not to use reserved keywords as function parameter names.
This commit:
* Renames the `$echo` parameter to `$display` in:
* `wp_nonce_field()`
* `wp_referer_field()`
* `wp_original_referer_field()`
* Renames the `$string` parameter to `$input_string` in
* `_wp_json_convert_string()`
* `_wp_to_kebab_case()`
* Renames the `$list` parameter to `$input_list` in:
* `wp_parse_list()`
* `wp_parse_id_list()`
* `wp_parse_slug_list()`
* `wp_filter_object_list()`
* `wp_list_filter()`
* `wp_list_pluck()`
* `wp_list_sort()`
* Renames the `$array` parameter to `$input_array` in:
* `add_magic_quotes()`
* `wp_array_slice_assoc()`
* `_wp_array_get()`
* `_wp_array_set()`
* Renames the `$function` parameter to `$function_name` in:
* `_deprecated_function()`
* `_deprecated_argument()`
* `_doing_it_wrong()`
* Renames the `$class` parameter to `$class_name` in `_deprecated_constructor()`.
* Renames the `$default` parameter to `$default_value` in `apache_mod_loaded()`.
* Renames the `$var` parameter to `$value` in `wp_validate_boolean()`.
* Amends the `$input` parameter in `wp_parse_str()` for consistency.
Follow-up to [52946], [52996], [52997], [52998], [53003], [53014], [53029], [53039], [53116], [53117], [53137], [53174], [53184], [53185], [53192], [53193], [53198], [53203], [53207], [53215], [53216], [53220], [53230], [53232], [53236], [53239], [53240], [53242], [53243], [53245], [53246], [53257], [53269], [53270], [53271], [53272], [53273], [53274], [53275], [53276], [53277], [53281], [53283], [53284], [53285], [53287], [53364], [53365], [54927].
Props jrf, aristath, poena, justinahinon, SergeyBiryukov.
See #56788.
Built from https://develop.svn.wordpress.org/trunk@54929
git-svn-id: http://core.svn.wordpress.org/trunk@54481 1a063a9b-81f0-0310-95a4-ce76da25c4cd
2022-12-03 10:07:14 -05:00
do_action ( 'deprecated_function_run' , $function_name , $replacement , $version );
2007-12-28 16:17:42 -05:00
2014-04-13 20:20:14 -04:00
/**
2016-05-22 14:36:27 -04:00
* Filters whether to trigger an error for deprecated functions .
2014-04-13 20:20:14 -04:00
*
* @ since 2.5 . 0
*
* @ param bool $trigger Whether to trigger the error for deprecated functions . Default true .
*/
2010-01-09 05:03:55 -05:00
if ( WP_DEBUG && apply_filters ( 'deprecated_function_trigger_error' , true ) ) {
2013-07-17 17:04:50 -04:00
if ( function_exists ( '__' ) ) {
2020-07-05 17:09:03 -04:00
if ( $replacement ) {
2019-10-31 20:41:01 -04:00
trigger_error (
sprintf (
/* translators: 1: PHP function name, 2: Version number, 3: Alternative function name. */
General: Clarify the deprecation messages in the `_deprecated_*()` functions family.
This makes the strings easier to translate and provides more details about what exactly is deprecated: a PHP function, a file name, or a WordPress hook.
The changes apply to:
* `_deprecated_function()`
* `_deprecated_constructor()`
* `_deprecated_file()`
* `_deprecated_argument()`
* `_deprecated_hook()`
* `_doing_it_wrong()`
Follow-up to [6514], [7884], [12536], [12584], [16939], [16942], [16945], [24439], [24723], [32989], [37861], [39315].
Props mukesh27, audrasjb, SergeyBiryukov.
Fixes #54658.
Built from https://develop.svn.wordpress.org/trunk@52609
git-svn-id: http://core.svn.wordpress.org/trunk@52197 1a063a9b-81f0-0310-95a4-ce76da25c4cd
2022-01-20 08:13:01 -05:00
__ ( 'Function %1$s is <strong>deprecated</strong> since version %2$s! Use %3$s instead.' ),
Code Modernization: Rename parameters that use reserved keywords in `wp-includes/functions.php`.
While using reserved PHP keywords as parameter name labels is allowed, in the context of function calls using named parameters in PHP 8.0+, this will easily lead to confusion. To avoid that, it is recommended not to use reserved keywords as function parameter names.
This commit:
* Renames the `$echo` parameter to `$display` in:
* `wp_nonce_field()`
* `wp_referer_field()`
* `wp_original_referer_field()`
* Renames the `$string` parameter to `$input_string` in
* `_wp_json_convert_string()`
* `_wp_to_kebab_case()`
* Renames the `$list` parameter to `$input_list` in:
* `wp_parse_list()`
* `wp_parse_id_list()`
* `wp_parse_slug_list()`
* `wp_filter_object_list()`
* `wp_list_filter()`
* `wp_list_pluck()`
* `wp_list_sort()`
* Renames the `$array` parameter to `$input_array` in:
* `add_magic_quotes()`
* `wp_array_slice_assoc()`
* `_wp_array_get()`
* `_wp_array_set()`
* Renames the `$function` parameter to `$function_name` in:
* `_deprecated_function()`
* `_deprecated_argument()`
* `_doing_it_wrong()`
* Renames the `$class` parameter to `$class_name` in `_deprecated_constructor()`.
* Renames the `$default` parameter to `$default_value` in `apache_mod_loaded()`.
* Renames the `$var` parameter to `$value` in `wp_validate_boolean()`.
* Amends the `$input` parameter in `wp_parse_str()` for consistency.
Follow-up to [52946], [52996], [52997], [52998], [53003], [53014], [53029], [53039], [53116], [53117], [53137], [53174], [53184], [53185], [53192], [53193], [53198], [53203], [53207], [53215], [53216], [53220], [53230], [53232], [53236], [53239], [53240], [53242], [53243], [53245], [53246], [53257], [53269], [53270], [53271], [53272], [53273], [53274], [53275], [53276], [53277], [53281], [53283], [53284], [53285], [53287], [53364], [53365], [54927].
Props jrf, aristath, poena, justinahinon, SergeyBiryukov.
See #56788.
Built from https://develop.svn.wordpress.org/trunk@54929
git-svn-id: http://core.svn.wordpress.org/trunk@54481 1a063a9b-81f0-0310-95a4-ce76da25c4cd
2022-12-03 10:07:14 -05:00
$function_name ,
2019-10-31 20:41:01 -04:00
$version ,
$replacement
),
E_USER_DEPRECATED
);
2016-11-18 21:39:33 -05:00
} else {
2019-10-31 20:41:01 -04:00
trigger_error (
sprintf (
/* translators: 1: PHP function name, 2: Version number. */
General: Clarify the deprecation messages in the `_deprecated_*()` functions family.
This makes the strings easier to translate and provides more details about what exactly is deprecated: a PHP function, a file name, or a WordPress hook.
The changes apply to:
* `_deprecated_function()`
* `_deprecated_constructor()`
* `_deprecated_file()`
* `_deprecated_argument()`
* `_deprecated_hook()`
* `_doing_it_wrong()`
Follow-up to [6514], [7884], [12536], [12584], [16939], [16942], [16945], [24439], [24723], [32989], [37861], [39315].
Props mukesh27, audrasjb, SergeyBiryukov.
Fixes #54658.
Built from https://develop.svn.wordpress.org/trunk@52609
git-svn-id: http://core.svn.wordpress.org/trunk@52197 1a063a9b-81f0-0310-95a4-ce76da25c4cd
2022-01-20 08:13:01 -05:00
__ ( 'Function %1$s is <strong>deprecated</strong> since version %2$s with no alternative available.' ),
Code Modernization: Rename parameters that use reserved keywords in `wp-includes/functions.php`.
While using reserved PHP keywords as parameter name labels is allowed, in the context of function calls using named parameters in PHP 8.0+, this will easily lead to confusion. To avoid that, it is recommended not to use reserved keywords as function parameter names.
This commit:
* Renames the `$echo` parameter to `$display` in:
* `wp_nonce_field()`
* `wp_referer_field()`
* `wp_original_referer_field()`
* Renames the `$string` parameter to `$input_string` in
* `_wp_json_convert_string()`
* `_wp_to_kebab_case()`
* Renames the `$list` parameter to `$input_list` in:
* `wp_parse_list()`
* `wp_parse_id_list()`
* `wp_parse_slug_list()`
* `wp_filter_object_list()`
* `wp_list_filter()`
* `wp_list_pluck()`
* `wp_list_sort()`
* Renames the `$array` parameter to `$input_array` in:
* `add_magic_quotes()`
* `wp_array_slice_assoc()`
* `_wp_array_get()`
* `_wp_array_set()`
* Renames the `$function` parameter to `$function_name` in:
* `_deprecated_function()`
* `_deprecated_argument()`
* `_doing_it_wrong()`
* Renames the `$class` parameter to `$class_name` in `_deprecated_constructor()`.
* Renames the `$default` parameter to `$default_value` in `apache_mod_loaded()`.
* Renames the `$var` parameter to `$value` in `wp_validate_boolean()`.
* Amends the `$input` parameter in `wp_parse_str()` for consistency.
Follow-up to [52946], [52996], [52997], [52998], [53003], [53014], [53029], [53039], [53116], [53117], [53137], [53174], [53184], [53185], [53192], [53193], [53198], [53203], [53207], [53215], [53216], [53220], [53230], [53232], [53236], [53239], [53240], [53242], [53243], [53245], [53246], [53257], [53269], [53270], [53271], [53272], [53273], [53274], [53275], [53276], [53277], [53281], [53283], [53284], [53285], [53287], [53364], [53365], [54927].
Props jrf, aristath, poena, justinahinon, SergeyBiryukov.
See #56788.
Built from https://develop.svn.wordpress.org/trunk@54929
git-svn-id: http://core.svn.wordpress.org/trunk@54481 1a063a9b-81f0-0310-95a4-ce76da25c4cd
2022-12-03 10:07:14 -05:00
$function_name ,
2019-10-31 20:41:01 -04:00
$version
),
E_USER_DEPRECATED
);
2016-11-18 21:39:33 -05:00
}
2013-07-17 17:04:50 -04:00
} else {
2020-07-05 17:09:03 -04:00
if ( $replacement ) {
2019-10-31 20:41:01 -04:00
trigger_error (
sprintf (
General: Clarify the deprecation messages in the `_deprecated_*()` functions family.
This makes the strings easier to translate and provides more details about what exactly is deprecated: a PHP function, a file name, or a WordPress hook.
The changes apply to:
* `_deprecated_function()`
* `_deprecated_constructor()`
* `_deprecated_file()`
* `_deprecated_argument()`
* `_deprecated_hook()`
* `_doing_it_wrong()`
Follow-up to [6514], [7884], [12536], [12584], [16939], [16942], [16945], [24439], [24723], [32989], [37861], [39315].
Props mukesh27, audrasjb, SergeyBiryukov.
Fixes #54658.
Built from https://develop.svn.wordpress.org/trunk@52609
git-svn-id: http://core.svn.wordpress.org/trunk@52197 1a063a9b-81f0-0310-95a4-ce76da25c4cd
2022-01-20 08:13:01 -05:00
'Function %1$s is <strong>deprecated</strong> since version %2$s! Use %3$s instead.' ,
Code Modernization: Rename parameters that use reserved keywords in `wp-includes/functions.php`.
While using reserved PHP keywords as parameter name labels is allowed, in the context of function calls using named parameters in PHP 8.0+, this will easily lead to confusion. To avoid that, it is recommended not to use reserved keywords as function parameter names.
This commit:
* Renames the `$echo` parameter to `$display` in:
* `wp_nonce_field()`
* `wp_referer_field()`
* `wp_original_referer_field()`
* Renames the `$string` parameter to `$input_string` in
* `_wp_json_convert_string()`
* `_wp_to_kebab_case()`
* Renames the `$list` parameter to `$input_list` in:
* `wp_parse_list()`
* `wp_parse_id_list()`
* `wp_parse_slug_list()`
* `wp_filter_object_list()`
* `wp_list_filter()`
* `wp_list_pluck()`
* `wp_list_sort()`
* Renames the `$array` parameter to `$input_array` in:
* `add_magic_quotes()`
* `wp_array_slice_assoc()`
* `_wp_array_get()`
* `_wp_array_set()`
* Renames the `$function` parameter to `$function_name` in:
* `_deprecated_function()`
* `_deprecated_argument()`
* `_doing_it_wrong()`
* Renames the `$class` parameter to `$class_name` in `_deprecated_constructor()`.
* Renames the `$default` parameter to `$default_value` in `apache_mod_loaded()`.
* Renames the `$var` parameter to `$value` in `wp_validate_boolean()`.
* Amends the `$input` parameter in `wp_parse_str()` for consistency.
Follow-up to [52946], [52996], [52997], [52998], [53003], [53014], [53029], [53039], [53116], [53117], [53137], [53174], [53184], [53185], [53192], [53193], [53198], [53203], [53207], [53215], [53216], [53220], [53230], [53232], [53236], [53239], [53240], [53242], [53243], [53245], [53246], [53257], [53269], [53270], [53271], [53272], [53273], [53274], [53275], [53276], [53277], [53281], [53283], [53284], [53285], [53287], [53364], [53365], [54927].
Props jrf, aristath, poena, justinahinon, SergeyBiryukov.
See #56788.
Built from https://develop.svn.wordpress.org/trunk@54929
git-svn-id: http://core.svn.wordpress.org/trunk@54481 1a063a9b-81f0-0310-95a4-ce76da25c4cd
2022-12-03 10:07:14 -05:00
$function_name ,
2019-10-31 20:41:01 -04:00
$version ,
$replacement
),
E_USER_DEPRECATED
);
2016-11-18 21:39:33 -05:00
} else {
2019-10-31 20:41:01 -04:00
trigger_error (
sprintf (
General: Clarify the deprecation messages in the `_deprecated_*()` functions family.
This makes the strings easier to translate and provides more details about what exactly is deprecated: a PHP function, a file name, or a WordPress hook.
The changes apply to:
* `_deprecated_function()`
* `_deprecated_constructor()`
* `_deprecated_file()`
* `_deprecated_argument()`
* `_deprecated_hook()`
* `_doing_it_wrong()`
Follow-up to [6514], [7884], [12536], [12584], [16939], [16942], [16945], [24439], [24723], [32989], [37861], [39315].
Props mukesh27, audrasjb, SergeyBiryukov.
Fixes #54658.
Built from https://develop.svn.wordpress.org/trunk@52609
git-svn-id: http://core.svn.wordpress.org/trunk@52197 1a063a9b-81f0-0310-95a4-ce76da25c4cd
2022-01-20 08:13:01 -05:00
'Function %1$s is <strong>deprecated</strong> since version %2$s with no alternative available.' ,
Code Modernization: Rename parameters that use reserved keywords in `wp-includes/functions.php`.
While using reserved PHP keywords as parameter name labels is allowed, in the context of function calls using named parameters in PHP 8.0+, this will easily lead to confusion. To avoid that, it is recommended not to use reserved keywords as function parameter names.
This commit:
* Renames the `$echo` parameter to `$display` in:
* `wp_nonce_field()`
* `wp_referer_field()`
* `wp_original_referer_field()`
* Renames the `$string` parameter to `$input_string` in
* `_wp_json_convert_string()`
* `_wp_to_kebab_case()`
* Renames the `$list` parameter to `$input_list` in:
* `wp_parse_list()`
* `wp_parse_id_list()`
* `wp_parse_slug_list()`
* `wp_filter_object_list()`
* `wp_list_filter()`
* `wp_list_pluck()`
* `wp_list_sort()`
* Renames the `$array` parameter to `$input_array` in:
* `add_magic_quotes()`
* `wp_array_slice_assoc()`
* `_wp_array_get()`
* `_wp_array_set()`
* Renames the `$function` parameter to `$function_name` in:
* `_deprecated_function()`
* `_deprecated_argument()`
* `_doing_it_wrong()`
* Renames the `$class` parameter to `$class_name` in `_deprecated_constructor()`.
* Renames the `$default` parameter to `$default_value` in `apache_mod_loaded()`.
* Renames the `$var` parameter to `$value` in `wp_validate_boolean()`.
* Amends the `$input` parameter in `wp_parse_str()` for consistency.
Follow-up to [52946], [52996], [52997], [52998], [53003], [53014], [53029], [53039], [53116], [53117], [53137], [53174], [53184], [53185], [53192], [53193], [53198], [53203], [53207], [53215], [53216], [53220], [53230], [53232], [53236], [53239], [53240], [53242], [53243], [53245], [53246], [53257], [53269], [53270], [53271], [53272], [53273], [53274], [53275], [53276], [53277], [53281], [53283], [53284], [53285], [53287], [53364], [53365], [54927].
Props jrf, aristath, poena, justinahinon, SergeyBiryukov.
See #56788.
Built from https://develop.svn.wordpress.org/trunk@54929
git-svn-id: http://core.svn.wordpress.org/trunk@54481 1a063a9b-81f0-0310-95a4-ce76da25c4cd
2022-12-03 10:07:14 -05:00
$function_name ,
2019-10-31 20:41:01 -04:00
$version
),
E_USER_DEPRECATED
);
2016-11-18 21:39:33 -05:00
}
2013-07-17 17:04:50 -04:00
}
2007-12-28 16:17:42 -05:00
}
}
2015-06-28 10:56:24 -04:00
/**
* Marks a constructor as deprecated and informs when it has been used .
*
* Similar to _deprecated_function (), but with different strings . Used to
* remove PHP4 style constructors .
*
2015-07-13 17:35:24 -04:00
* The current behavior is to trigger a user error if `WP_DEBUG` is true .
2015-06-28 10:56:24 -04:00
*
* This function is to be used in every PHP4 style constructor method that is deprecated .
*
* @ since 4.3 . 0
2016-02-16 18:20:26 -05:00
* @ since 4.5 . 0 Added the `$parent_class` parameter .
2019-10-27 10:21:03 -04:00
* @ since 5.4 . 0 This function is no longer marked as " private " .
2019-10-31 20:41:01 -04:00
* @ since 5.4 . 0 The error type is now classified as E_USER_DEPRECATED ( used to default to E_USER_NOTICE ) .
2015-06-28 10:56:24 -04:00
*
Code Modernization: Rename parameters that use reserved keywords in `wp-includes/functions.php`.
While using reserved PHP keywords as parameter name labels is allowed, in the context of function calls using named parameters in PHP 8.0+, this will easily lead to confusion. To avoid that, it is recommended not to use reserved keywords as function parameter names.
This commit:
* Renames the `$echo` parameter to `$display` in:
* `wp_nonce_field()`
* `wp_referer_field()`
* `wp_original_referer_field()`
* Renames the `$string` parameter to `$input_string` in
* `_wp_json_convert_string()`
* `_wp_to_kebab_case()`
* Renames the `$list` parameter to `$input_list` in:
* `wp_parse_list()`
* `wp_parse_id_list()`
* `wp_parse_slug_list()`
* `wp_filter_object_list()`
* `wp_list_filter()`
* `wp_list_pluck()`
* `wp_list_sort()`
* Renames the `$array` parameter to `$input_array` in:
* `add_magic_quotes()`
* `wp_array_slice_assoc()`
* `_wp_array_get()`
* `_wp_array_set()`
* Renames the `$function` parameter to `$function_name` in:
* `_deprecated_function()`
* `_deprecated_argument()`
* `_doing_it_wrong()`
* Renames the `$class` parameter to `$class_name` in `_deprecated_constructor()`.
* Renames the `$default` parameter to `$default_value` in `apache_mod_loaded()`.
* Renames the `$var` parameter to `$value` in `wp_validate_boolean()`.
* Amends the `$input` parameter in `wp_parse_str()` for consistency.
Follow-up to [52946], [52996], [52997], [52998], [53003], [53014], [53029], [53039], [53116], [53117], [53137], [53174], [53184], [53185], [53192], [53193], [53198], [53203], [53207], [53215], [53216], [53220], [53230], [53232], [53236], [53239], [53240], [53242], [53243], [53245], [53246], [53257], [53269], [53270], [53271], [53272], [53273], [53274], [53275], [53276], [53277], [53281], [53283], [53284], [53285], [53287], [53364], [53365], [54927].
Props jrf, aristath, poena, justinahinon, SergeyBiryukov.
See #56788.
Built from https://develop.svn.wordpress.org/trunk@54929
git-svn-id: http://core.svn.wordpress.org/trunk@54481 1a063a9b-81f0-0310-95a4-ce76da25c4cd
2022-12-03 10:07:14 -05:00
* @ param string $class_name The class containing the deprecated constructor .
2016-02-16 18:20:26 -05:00
* @ param string $version The version of WordPress that deprecated the function .
* @ param string $parent_class Optional . The parent class calling the deprecated constructor .
* Default empty string .
2015-06-28 10:56:24 -04:00
*/
Code Modernization: Rename parameters that use reserved keywords in `wp-includes/functions.php`.
While using reserved PHP keywords as parameter name labels is allowed, in the context of function calls using named parameters in PHP 8.0+, this will easily lead to confusion. To avoid that, it is recommended not to use reserved keywords as function parameter names.
This commit:
* Renames the `$echo` parameter to `$display` in:
* `wp_nonce_field()`
* `wp_referer_field()`
* `wp_original_referer_field()`
* Renames the `$string` parameter to `$input_string` in
* `_wp_json_convert_string()`
* `_wp_to_kebab_case()`
* Renames the `$list` parameter to `$input_list` in:
* `wp_parse_list()`
* `wp_parse_id_list()`
* `wp_parse_slug_list()`
* `wp_filter_object_list()`
* `wp_list_filter()`
* `wp_list_pluck()`
* `wp_list_sort()`
* Renames the `$array` parameter to `$input_array` in:
* `add_magic_quotes()`
* `wp_array_slice_assoc()`
* `_wp_array_get()`
* `_wp_array_set()`
* Renames the `$function` parameter to `$function_name` in:
* `_deprecated_function()`
* `_deprecated_argument()`
* `_doing_it_wrong()`
* Renames the `$class` parameter to `$class_name` in `_deprecated_constructor()`.
* Renames the `$default` parameter to `$default_value` in `apache_mod_loaded()`.
* Renames the `$var` parameter to `$value` in `wp_validate_boolean()`.
* Amends the `$input` parameter in `wp_parse_str()` for consistency.
Follow-up to [52946], [52996], [52997], [52998], [53003], [53014], [53029], [53039], [53116], [53117], [53137], [53174], [53184], [53185], [53192], [53193], [53198], [53203], [53207], [53215], [53216], [53220], [53230], [53232], [53236], [53239], [53240], [53242], [53243], [53245], [53246], [53257], [53269], [53270], [53271], [53272], [53273], [53274], [53275], [53276], [53277], [53281], [53283], [53284], [53285], [53287], [53364], [53365], [54927].
Props jrf, aristath, poena, justinahinon, SergeyBiryukov.
See #56788.
Built from https://develop.svn.wordpress.org/trunk@54929
git-svn-id: http://core.svn.wordpress.org/trunk@54481 1a063a9b-81f0-0310-95a4-ce76da25c4cd
2022-12-03 10:07:14 -05:00
function _deprecated_constructor ( $class_name , $version , $parent_class = '' ) {
2015-06-28 10:56:24 -04:00
/**
* Fires when a deprecated constructor is called .
*
* @ since 4.3 . 0
2016-02-16 18:20:26 -05:00
* @ since 4.5 . 0 Added the `$parent_class` parameter .
2015-06-28 10:56:24 -04:00
*
Code Modernization: Rename parameters that use reserved keywords in `wp-includes/functions.php`.
While using reserved PHP keywords as parameter name labels is allowed, in the context of function calls using named parameters in PHP 8.0+, this will easily lead to confusion. To avoid that, it is recommended not to use reserved keywords as function parameter names.
This commit:
* Renames the `$echo` parameter to `$display` in:
* `wp_nonce_field()`
* `wp_referer_field()`
* `wp_original_referer_field()`
* Renames the `$string` parameter to `$input_string` in
* `_wp_json_convert_string()`
* `_wp_to_kebab_case()`
* Renames the `$list` parameter to `$input_list` in:
* `wp_parse_list()`
* `wp_parse_id_list()`
* `wp_parse_slug_list()`
* `wp_filter_object_list()`
* `wp_list_filter()`
* `wp_list_pluck()`
* `wp_list_sort()`
* Renames the `$array` parameter to `$input_array` in:
* `add_magic_quotes()`
* `wp_array_slice_assoc()`
* `_wp_array_get()`
* `_wp_array_set()`
* Renames the `$function` parameter to `$function_name` in:
* `_deprecated_function()`
* `_deprecated_argument()`
* `_doing_it_wrong()`
* Renames the `$class` parameter to `$class_name` in `_deprecated_constructor()`.
* Renames the `$default` parameter to `$default_value` in `apache_mod_loaded()`.
* Renames the `$var` parameter to `$value` in `wp_validate_boolean()`.
* Amends the `$input` parameter in `wp_parse_str()` for consistency.
Follow-up to [52946], [52996], [52997], [52998], [53003], [53014], [53029], [53039], [53116], [53117], [53137], [53174], [53184], [53185], [53192], [53193], [53198], [53203], [53207], [53215], [53216], [53220], [53230], [53232], [53236], [53239], [53240], [53242], [53243], [53245], [53246], [53257], [53269], [53270], [53271], [53272], [53273], [53274], [53275], [53276], [53277], [53281], [53283], [53284], [53285], [53287], [53364], [53365], [54927].
Props jrf, aristath, poena, justinahinon, SergeyBiryukov.
See #56788.
Built from https://develop.svn.wordpress.org/trunk@54929
git-svn-id: http://core.svn.wordpress.org/trunk@54481 1a063a9b-81f0-0310-95a4-ce76da25c4cd
2022-12-03 10:07:14 -05:00
* @ param string $class_name The class containing the deprecated constructor .
2016-02-16 18:20:26 -05:00
* @ param string $version The version of WordPress that deprecated the function .
* @ param string $parent_class The parent class calling the deprecated constructor .
2015-06-28 10:56:24 -04:00
*/
Code Modernization: Rename parameters that use reserved keywords in `wp-includes/functions.php`.
While using reserved PHP keywords as parameter name labels is allowed, in the context of function calls using named parameters in PHP 8.0+, this will easily lead to confusion. To avoid that, it is recommended not to use reserved keywords as function parameter names.
This commit:
* Renames the `$echo` parameter to `$display` in:
* `wp_nonce_field()`
* `wp_referer_field()`
* `wp_original_referer_field()`
* Renames the `$string` parameter to `$input_string` in
* `_wp_json_convert_string()`
* `_wp_to_kebab_case()`
* Renames the `$list` parameter to `$input_list` in:
* `wp_parse_list()`
* `wp_parse_id_list()`
* `wp_parse_slug_list()`
* `wp_filter_object_list()`
* `wp_list_filter()`
* `wp_list_pluck()`
* `wp_list_sort()`
* Renames the `$array` parameter to `$input_array` in:
* `add_magic_quotes()`
* `wp_array_slice_assoc()`
* `_wp_array_get()`
* `_wp_array_set()`
* Renames the `$function` parameter to `$function_name` in:
* `_deprecated_function()`
* `_deprecated_argument()`
* `_doing_it_wrong()`
* Renames the `$class` parameter to `$class_name` in `_deprecated_constructor()`.
* Renames the `$default` parameter to `$default_value` in `apache_mod_loaded()`.
* Renames the `$var` parameter to `$value` in `wp_validate_boolean()`.
* Amends the `$input` parameter in `wp_parse_str()` for consistency.
Follow-up to [52946], [52996], [52997], [52998], [53003], [53014], [53029], [53039], [53116], [53117], [53137], [53174], [53184], [53185], [53192], [53193], [53198], [53203], [53207], [53215], [53216], [53220], [53230], [53232], [53236], [53239], [53240], [53242], [53243], [53245], [53246], [53257], [53269], [53270], [53271], [53272], [53273], [53274], [53275], [53276], [53277], [53281], [53283], [53284], [53285], [53287], [53364], [53365], [54927].
Props jrf, aristath, poena, justinahinon, SergeyBiryukov.
See #56788.
Built from https://develop.svn.wordpress.org/trunk@54929
git-svn-id: http://core.svn.wordpress.org/trunk@54481 1a063a9b-81f0-0310-95a4-ce76da25c4cd
2022-12-03 10:07:14 -05:00
do_action ( 'deprecated_constructor_run' , $class_name , $version , $parent_class );
2015-06-28 10:56:24 -04:00
/**
2016-05-22 14:36:27 -04:00
* Filters whether to trigger an error for deprecated functions .
2015-06-28 10:56:24 -04:00
*
2015-07-13 17:35:24 -04:00
* `WP_DEBUG` must be true in addition to the filter evaluating to true .
*
2015-06-28 10:56:24 -04:00
* @ since 4.3 . 0
*
* @ param bool $trigger Whether to trigger the error for deprecated functions . Default true .
*/
if ( WP_DEBUG && apply_filters ( 'deprecated_constructor_trigger_error' , true ) ) {
if ( function_exists ( '__' ) ) {
2020-07-05 17:09:03 -04:00
if ( $parent_class ) {
2017-11-30 18:11:00 -05:00
trigger_error (
sprintf (
2019-09-02 20:41:05 -04:00
/* translators: 1: PHP class name, 2: PHP parent class name, 3: Version number, 4: __construct() method. */
General: Clarify the deprecation messages in the `_deprecated_*()` functions family.
This makes the strings easier to translate and provides more details about what exactly is deprecated: a PHP function, a file name, or a WordPress hook.
The changes apply to:
* `_deprecated_function()`
* `_deprecated_constructor()`
* `_deprecated_file()`
* `_deprecated_argument()`
* `_deprecated_hook()`
* `_doing_it_wrong()`
Follow-up to [6514], [7884], [12536], [12584], [16939], [16942], [16945], [24439], [24723], [32989], [37861], [39315].
Props mukesh27, audrasjb, SergeyBiryukov.
Fixes #54658.
Built from https://develop.svn.wordpress.org/trunk@52609
git-svn-id: http://core.svn.wordpress.org/trunk@52197 1a063a9b-81f0-0310-95a4-ce76da25c4cd
2022-01-20 08:13:01 -05:00
__ ( 'The called constructor method for %1$s class in %2$s is <strong>deprecated</strong> since version %3$s! Use %4$s instead.' ),
Code Modernization: Rename parameters that use reserved keywords in `wp-includes/functions.php`.
While using reserved PHP keywords as parameter name labels is allowed, in the context of function calls using named parameters in PHP 8.0+, this will easily lead to confusion. To avoid that, it is recommended not to use reserved keywords as function parameter names.
This commit:
* Renames the `$echo` parameter to `$display` in:
* `wp_nonce_field()`
* `wp_referer_field()`
* `wp_original_referer_field()`
* Renames the `$string` parameter to `$input_string` in
* `_wp_json_convert_string()`
* `_wp_to_kebab_case()`
* Renames the `$list` parameter to `$input_list` in:
* `wp_parse_list()`
* `wp_parse_id_list()`
* `wp_parse_slug_list()`
* `wp_filter_object_list()`
* `wp_list_filter()`
* `wp_list_pluck()`
* `wp_list_sort()`
* Renames the `$array` parameter to `$input_array` in:
* `add_magic_quotes()`
* `wp_array_slice_assoc()`
* `_wp_array_get()`
* `_wp_array_set()`
* Renames the `$function` parameter to `$function_name` in:
* `_deprecated_function()`
* `_deprecated_argument()`
* `_doing_it_wrong()`
* Renames the `$class` parameter to `$class_name` in `_deprecated_constructor()`.
* Renames the `$default` parameter to `$default_value` in `apache_mod_loaded()`.
* Renames the `$var` parameter to `$value` in `wp_validate_boolean()`.
* Amends the `$input` parameter in `wp_parse_str()` for consistency.
Follow-up to [52946], [52996], [52997], [52998], [53003], [53014], [53029], [53039], [53116], [53117], [53137], [53174], [53184], [53185], [53192], [53193], [53198], [53203], [53207], [53215], [53216], [53220], [53230], [53232], [53236], [53239], [53240], [53242], [53243], [53245], [53246], [53257], [53269], [53270], [53271], [53272], [53273], [53274], [53275], [53276], [53277], [53281], [53283], [53284], [53285], [53287], [53364], [53365], [54927].
Props jrf, aristath, poena, justinahinon, SergeyBiryukov.
See #56788.
Built from https://develop.svn.wordpress.org/trunk@54929
git-svn-id: http://core.svn.wordpress.org/trunk@54481 1a063a9b-81f0-0310-95a4-ce76da25c4cd
2022-12-03 10:07:14 -05:00
$class_name ,
2018-08-16 21:51:36 -04:00
$parent_class ,
$version ,
2019-11-03 05:56:03 -05:00
'<code>__construct()</code>'
2019-10-31 20:41:01 -04:00
),
E_USER_DEPRECATED
2017-11-30 18:11:00 -05:00
);
2016-02-16 18:20:26 -05:00
} else {
2017-11-30 18:11:00 -05:00
trigger_error (
sprintf (
2019-09-02 20:41:05 -04:00
/* translators: 1: PHP class name, 2: Version number, 3: __construct() method. */
General: Clarify the deprecation messages in the `_deprecated_*()` functions family.
This makes the strings easier to translate and provides more details about what exactly is deprecated: a PHP function, a file name, or a WordPress hook.
The changes apply to:
* `_deprecated_function()`
* `_deprecated_constructor()`
* `_deprecated_file()`
* `_deprecated_argument()`
* `_deprecated_hook()`
* `_doing_it_wrong()`
Follow-up to [6514], [7884], [12536], [12584], [16939], [16942], [16945], [24439], [24723], [32989], [37861], [39315].
Props mukesh27, audrasjb, SergeyBiryukov.
Fixes #54658.
Built from https://develop.svn.wordpress.org/trunk@52609
git-svn-id: http://core.svn.wordpress.org/trunk@52197 1a063a9b-81f0-0310-95a4-ce76da25c4cd
2022-01-20 08:13:01 -05:00
__ ( 'The called constructor method for %1$s class is <strong>deprecated</strong> since version %2$s! Use %3$s instead.' ),
Code Modernization: Rename parameters that use reserved keywords in `wp-includes/functions.php`.
While using reserved PHP keywords as parameter name labels is allowed, in the context of function calls using named parameters in PHP 8.0+, this will easily lead to confusion. To avoid that, it is recommended not to use reserved keywords as function parameter names.
This commit:
* Renames the `$echo` parameter to `$display` in:
* `wp_nonce_field()`
* `wp_referer_field()`
* `wp_original_referer_field()`
* Renames the `$string` parameter to `$input_string` in
* `_wp_json_convert_string()`
* `_wp_to_kebab_case()`
* Renames the `$list` parameter to `$input_list` in:
* `wp_parse_list()`
* `wp_parse_id_list()`
* `wp_parse_slug_list()`
* `wp_filter_object_list()`
* `wp_list_filter()`
* `wp_list_pluck()`
* `wp_list_sort()`
* Renames the `$array` parameter to `$input_array` in:
* `add_magic_quotes()`
* `wp_array_slice_assoc()`
* `_wp_array_get()`
* `_wp_array_set()`
* Renames the `$function` parameter to `$function_name` in:
* `_deprecated_function()`
* `_deprecated_argument()`
* `_doing_it_wrong()`
* Renames the `$class` parameter to `$class_name` in `_deprecated_constructor()`.
* Renames the `$default` parameter to `$default_value` in `apache_mod_loaded()`.
* Renames the `$var` parameter to `$value` in `wp_validate_boolean()`.
* Amends the `$input` parameter in `wp_parse_str()` for consistency.
Follow-up to [52946], [52996], [52997], [52998], [53003], [53014], [53029], [53039], [53116], [53117], [53137], [53174], [53184], [53185], [53192], [53193], [53198], [53203], [53207], [53215], [53216], [53220], [53230], [53232], [53236], [53239], [53240], [53242], [53243], [53245], [53246], [53257], [53269], [53270], [53271], [53272], [53273], [53274], [53275], [53276], [53277], [53281], [53283], [53284], [53285], [53287], [53364], [53365], [54927].
Props jrf, aristath, poena, justinahinon, SergeyBiryukov.
See #56788.
Built from https://develop.svn.wordpress.org/trunk@54929
git-svn-id: http://core.svn.wordpress.org/trunk@54481 1a063a9b-81f0-0310-95a4-ce76da25c4cd
2022-12-03 10:07:14 -05:00
$class_name ,
2018-08-16 21:51:36 -04:00
$version ,
2019-11-03 05:56:03 -05:00
'<code>__construct()</code>'
2019-10-31 20:41:01 -04:00
),
E_USER_DEPRECATED
2017-11-30 18:11:00 -05:00
);
2016-02-16 18:20:26 -05:00
}
2015-06-28 10:56:24 -04:00
} else {
2020-07-05 17:09:03 -04:00
if ( $parent_class ) {
2017-11-30 18:11:00 -05:00
trigger_error (
sprintf (
General: Clarify the deprecation messages in the `_deprecated_*()` functions family.
This makes the strings easier to translate and provides more details about what exactly is deprecated: a PHP function, a file name, or a WordPress hook.
The changes apply to:
* `_deprecated_function()`
* `_deprecated_constructor()`
* `_deprecated_file()`
* `_deprecated_argument()`
* `_deprecated_hook()`
* `_doing_it_wrong()`
Follow-up to [6514], [7884], [12536], [12584], [16939], [16942], [16945], [24439], [24723], [32989], [37861], [39315].
Props mukesh27, audrasjb, SergeyBiryukov.
Fixes #54658.
Built from https://develop.svn.wordpress.org/trunk@52609
git-svn-id: http://core.svn.wordpress.org/trunk@52197 1a063a9b-81f0-0310-95a4-ce76da25c4cd
2022-01-20 08:13:01 -05:00
'The called constructor method for %1$s class in %2$s is <strong>deprecated</strong> since version %3$s! Use %4$s instead.' ,
Code Modernization: Rename parameters that use reserved keywords in `wp-includes/functions.php`.
While using reserved PHP keywords as parameter name labels is allowed, in the context of function calls using named parameters in PHP 8.0+, this will easily lead to confusion. To avoid that, it is recommended not to use reserved keywords as function parameter names.
This commit:
* Renames the `$echo` parameter to `$display` in:
* `wp_nonce_field()`
* `wp_referer_field()`
* `wp_original_referer_field()`
* Renames the `$string` parameter to `$input_string` in
* `_wp_json_convert_string()`
* `_wp_to_kebab_case()`
* Renames the `$list` parameter to `$input_list` in:
* `wp_parse_list()`
* `wp_parse_id_list()`
* `wp_parse_slug_list()`
* `wp_filter_object_list()`
* `wp_list_filter()`
* `wp_list_pluck()`
* `wp_list_sort()`
* Renames the `$array` parameter to `$input_array` in:
* `add_magic_quotes()`
* `wp_array_slice_assoc()`
* `_wp_array_get()`
* `_wp_array_set()`
* Renames the `$function` parameter to `$function_name` in:
* `_deprecated_function()`
* `_deprecated_argument()`
* `_doing_it_wrong()`
* Renames the `$class` parameter to `$class_name` in `_deprecated_constructor()`.
* Renames the `$default` parameter to `$default_value` in `apache_mod_loaded()`.
* Renames the `$var` parameter to `$value` in `wp_validate_boolean()`.
* Amends the `$input` parameter in `wp_parse_str()` for consistency.
Follow-up to [52946], [52996], [52997], [52998], [53003], [53014], [53029], [53039], [53116], [53117], [53137], [53174], [53184], [53185], [53192], [53193], [53198], [53203], [53207], [53215], [53216], [53220], [53230], [53232], [53236], [53239], [53240], [53242], [53243], [53245], [53246], [53257], [53269], [53270], [53271], [53272], [53273], [53274], [53275], [53276], [53277], [53281], [53283], [53284], [53285], [53287], [53364], [53365], [54927].
Props jrf, aristath, poena, justinahinon, SergeyBiryukov.
See #56788.
Built from https://develop.svn.wordpress.org/trunk@54929
git-svn-id: http://core.svn.wordpress.org/trunk@54481 1a063a9b-81f0-0310-95a4-ce76da25c4cd
2022-12-03 10:07:14 -05:00
$class_name ,
2018-08-16 21:51:36 -04:00
$parent_class ,
$version ,
2019-11-03 05:56:03 -05:00
'<code>__construct()</code>'
2019-10-31 20:41:01 -04:00
),
E_USER_DEPRECATED
2017-11-30 18:11:00 -05:00
);
2016-02-16 18:20:26 -05:00
} else {
2017-11-30 18:11:00 -05:00
trigger_error (
sprintf (
General: Clarify the deprecation messages in the `_deprecated_*()` functions family.
This makes the strings easier to translate and provides more details about what exactly is deprecated: a PHP function, a file name, or a WordPress hook.
The changes apply to:
* `_deprecated_function()`
* `_deprecated_constructor()`
* `_deprecated_file()`
* `_deprecated_argument()`
* `_deprecated_hook()`
* `_doing_it_wrong()`
Follow-up to [6514], [7884], [12536], [12584], [16939], [16942], [16945], [24439], [24723], [32989], [37861], [39315].
Props mukesh27, audrasjb, SergeyBiryukov.
Fixes #54658.
Built from https://develop.svn.wordpress.org/trunk@52609
git-svn-id: http://core.svn.wordpress.org/trunk@52197 1a063a9b-81f0-0310-95a4-ce76da25c4cd
2022-01-20 08:13:01 -05:00
'The called constructor method for %1$s class is <strong>deprecated</strong> since version %2$s! Use %3$s instead.' ,
Code Modernization: Rename parameters that use reserved keywords in `wp-includes/functions.php`.
While using reserved PHP keywords as parameter name labels is allowed, in the context of function calls using named parameters in PHP 8.0+, this will easily lead to confusion. To avoid that, it is recommended not to use reserved keywords as function parameter names.
This commit:
* Renames the `$echo` parameter to `$display` in:
* `wp_nonce_field()`
* `wp_referer_field()`
* `wp_original_referer_field()`
* Renames the `$string` parameter to `$input_string` in
* `_wp_json_convert_string()`
* `_wp_to_kebab_case()`
* Renames the `$list` parameter to `$input_list` in:
* `wp_parse_list()`
* `wp_parse_id_list()`
* `wp_parse_slug_list()`
* `wp_filter_object_list()`
* `wp_list_filter()`
* `wp_list_pluck()`
* `wp_list_sort()`
* Renames the `$array` parameter to `$input_array` in:
* `add_magic_quotes()`
* `wp_array_slice_assoc()`
* `_wp_array_get()`
* `_wp_array_set()`
* Renames the `$function` parameter to `$function_name` in:
* `_deprecated_function()`
* `_deprecated_argument()`
* `_doing_it_wrong()`
* Renames the `$class` parameter to `$class_name` in `_deprecated_constructor()`.
* Renames the `$default` parameter to `$default_value` in `apache_mod_loaded()`.
* Renames the `$var` parameter to `$value` in `wp_validate_boolean()`.
* Amends the `$input` parameter in `wp_parse_str()` for consistency.
Follow-up to [52946], [52996], [52997], [52998], [53003], [53014], [53029], [53039], [53116], [53117], [53137], [53174], [53184], [53185], [53192], [53193], [53198], [53203], [53207], [53215], [53216], [53220], [53230], [53232], [53236], [53239], [53240], [53242], [53243], [53245], [53246], [53257], [53269], [53270], [53271], [53272], [53273], [53274], [53275], [53276], [53277], [53281], [53283], [53284], [53285], [53287], [53364], [53365], [54927].
Props jrf, aristath, poena, justinahinon, SergeyBiryukov.
See #56788.
Built from https://develop.svn.wordpress.org/trunk@54929
git-svn-id: http://core.svn.wordpress.org/trunk@54481 1a063a9b-81f0-0310-95a4-ce76da25c4cd
2022-12-03 10:07:14 -05:00
$class_name ,
2018-08-16 21:51:36 -04:00
$version ,
2019-11-03 05:56:03 -05:00
'<code>__construct()</code>'
2019-10-31 20:41:01 -04:00
),
E_USER_DEPRECATED
2017-11-30 18:11:00 -05:00
);
2016-02-16 18:20:26 -05:00
}
2015-06-28 10:56:24 -04:00
}
}
}
2007-12-28 16:17:42 -05:00
/**
2022-08-12 05:53:11 -04:00
* Marks a file as deprecated and inform when it has been used .
2007-12-28 16:17:42 -05:00
*
2016-05-23 15:01:27 -04:00
* There is a hook { @ see 'deprecated_file_included' } that will be called that can be used
2008-06-15 05:38:32 -04:00
* to get the backtrace up to what file and function included the deprecated
* file .
2007-12-28 16:17:42 -05:00
*
2016-05-23 15:01:27 -04:00
* The current behavior is to trigger a user error if `WP_DEBUG` is true .
2008-02-05 01:47:27 -05:00
*
2010-12-15 07:09:53 -05:00
* This function is to be used in every file that is deprecated .
2007-12-28 16:17:42 -05:00
*
2008-08-10 12:45:50 -04:00
* @ since 2.5 . 0
2019-10-27 10:21:03 -04:00
* @ since 5.4 . 0 This function is no longer marked as " private " .
2019-10-31 20:41:01 -04:00
* @ since 5.4 . 0 The error type is now classified as E_USER_DEPRECATED ( used to default to E_USER_NOTICE ) .
2007-12-28 16:17:42 -05:00
*
2014-07-07 02:19:14 -04:00
* @ param string $file The file that was included .
* @ param string $version The version of WordPress that deprecated the file .
* @ param string $replacement Optional . The file that should have been included based on ABSPATH .
2023-02-21 11:39:19 -05:00
* Default empty string .
* @ param string $message Optional . A message regarding the change . Default empty string .
2007-12-28 16:17:42 -05:00
*/
2020-07-05 17:09:03 -04:00
function _deprecated_file ( $file , $version , $replacement = '' , $message = '' ) {
2007-12-28 16:17:42 -05:00
2014-04-13 20:20:14 -04:00
/**
* Fires when a deprecated file is called .
*
* @ since 2.5 . 0
*
* @ param string $file The file that was called .
* @ param string $replacement The file that should have been included based on ABSPATH .
* @ param string $version The version of WordPress that deprecated the file .
* @ param string $message A message regarding the change .
*/
2010-02-05 16:40:22 -05:00
do_action ( 'deprecated_file_included' , $file , $replacement , $version , $message );
2007-12-28 16:17:42 -05:00
2014-04-13 20:20:14 -04:00
/**
2016-05-22 14:36:27 -04:00
* Filters whether to trigger an error for deprecated files .
2014-04-13 20:20:14 -04:00
*
* @ since 2.5 . 0
*
* @ param bool $trigger Whether to trigger the error for deprecated files . Default true .
*/
2010-01-09 05:03:55 -05:00
if ( WP_DEBUG && apply_filters ( 'deprecated_file_trigger_error' , true ) ) {
2010-02-05 16:40:22 -05:00
$message = empty ( $message ) ? '' : ' ' . $message ;
2019-10-31 20:41:01 -04:00
2013-07-17 17:04:50 -04:00
if ( function_exists ( '__' ) ) {
2020-07-05 17:09:03 -04:00
if ( $replacement ) {
2019-10-31 20:41:01 -04:00
trigger_error (
sprintf (
/* translators: 1: PHP file name, 2: Version number, 3: Alternative file name. */
General: Clarify the deprecation messages in the `_deprecated_*()` functions family.
This makes the strings easier to translate and provides more details about what exactly is deprecated: a PHP function, a file name, or a WordPress hook.
The changes apply to:
* `_deprecated_function()`
* `_deprecated_constructor()`
* `_deprecated_file()`
* `_deprecated_argument()`
* `_deprecated_hook()`
* `_doing_it_wrong()`
Follow-up to [6514], [7884], [12536], [12584], [16939], [16942], [16945], [24439], [24723], [32989], [37861], [39315].
Props mukesh27, audrasjb, SergeyBiryukov.
Fixes #54658.
Built from https://develop.svn.wordpress.org/trunk@52609
git-svn-id: http://core.svn.wordpress.org/trunk@52197 1a063a9b-81f0-0310-95a4-ce76da25c4cd
2022-01-20 08:13:01 -05:00
__ ( 'File %1$s is <strong>deprecated</strong> since version %2$s! Use %3$s instead.' ),
2019-10-31 20:41:01 -04:00
$file ,
$version ,
$replacement
) . $message ,
E_USER_DEPRECATED
);
2016-11-18 21:39:33 -05:00
} else {
2019-10-31 20:41:01 -04:00
trigger_error (
sprintf (
/* translators: 1: PHP file name, 2: Version number. */
General: Clarify the deprecation messages in the `_deprecated_*()` functions family.
This makes the strings easier to translate and provides more details about what exactly is deprecated: a PHP function, a file name, or a WordPress hook.
The changes apply to:
* `_deprecated_function()`
* `_deprecated_constructor()`
* `_deprecated_file()`
* `_deprecated_argument()`
* `_deprecated_hook()`
* `_doing_it_wrong()`
Follow-up to [6514], [7884], [12536], [12584], [16939], [16942], [16945], [24439], [24723], [32989], [37861], [39315].
Props mukesh27, audrasjb, SergeyBiryukov.
Fixes #54658.
Built from https://develop.svn.wordpress.org/trunk@52609
git-svn-id: http://core.svn.wordpress.org/trunk@52197 1a063a9b-81f0-0310-95a4-ce76da25c4cd
2022-01-20 08:13:01 -05:00
__ ( 'File %1$s is <strong>deprecated</strong> since version %2$s with no alternative available.' ),
2019-10-31 20:41:01 -04:00
$file ,
$version
) . $message ,
E_USER_DEPRECATED
);
2016-11-18 21:39:33 -05:00
}
2013-07-17 17:04:50 -04:00
} else {
2020-07-05 17:09:03 -04:00
if ( $replacement ) {
2019-10-31 20:41:01 -04:00
trigger_error (
sprintf (
General: Clarify the deprecation messages in the `_deprecated_*()` functions family.
This makes the strings easier to translate and provides more details about what exactly is deprecated: a PHP function, a file name, or a WordPress hook.
The changes apply to:
* `_deprecated_function()`
* `_deprecated_constructor()`
* `_deprecated_file()`
* `_deprecated_argument()`
* `_deprecated_hook()`
* `_doing_it_wrong()`
Follow-up to [6514], [7884], [12536], [12584], [16939], [16942], [16945], [24439], [24723], [32989], [37861], [39315].
Props mukesh27, audrasjb, SergeyBiryukov.
Fixes #54658.
Built from https://develop.svn.wordpress.org/trunk@52609
git-svn-id: http://core.svn.wordpress.org/trunk@52197 1a063a9b-81f0-0310-95a4-ce76da25c4cd
2022-01-20 08:13:01 -05:00
'File %1$s is <strong>deprecated</strong> since version %2$s! Use %3$s instead.' ,
2019-10-31 20:41:01 -04:00
$file ,
$version ,
$replacement
) . $message ,
E_USER_DEPRECATED
);
2016-11-18 21:39:33 -05:00
} else {
2019-10-31 20:41:01 -04:00
trigger_error (
sprintf (
General: Clarify the deprecation messages in the `_deprecated_*()` functions family.
This makes the strings easier to translate and provides more details about what exactly is deprecated: a PHP function, a file name, or a WordPress hook.
The changes apply to:
* `_deprecated_function()`
* `_deprecated_constructor()`
* `_deprecated_file()`
* `_deprecated_argument()`
* `_deprecated_hook()`
* `_doing_it_wrong()`
Follow-up to [6514], [7884], [12536], [12584], [16939], [16942], [16945], [24439], [24723], [32989], [37861], [39315].
Props mukesh27, audrasjb, SergeyBiryukov.
Fixes #54658.
Built from https://develop.svn.wordpress.org/trunk@52609
git-svn-id: http://core.svn.wordpress.org/trunk@52197 1a063a9b-81f0-0310-95a4-ce76da25c4cd
2022-01-20 08:13:01 -05:00
'File %1$s is <strong>deprecated</strong> since version %2$s with no alternative available.' ,
2019-10-31 20:41:01 -04:00
$file ,
$version
) . $message ,
E_USER_DEPRECATED
);
2016-11-18 21:39:33 -05:00
}
2013-07-17 17:04:50 -04:00
}
2007-12-28 16:17:42 -05:00
}
}
2009-12-24 06:06:00 -05:00
/**
2022-08-12 05:53:11 -04:00
* Marks a function argument as deprecated and inform when it has been used .
2009-12-24 06:06:00 -05:00
*
* This function is to be used whenever a deprecated function argument is used .
* Before this function is called , the argument must be checked for whether it was
* used by comparing it to its default value or evaluating whether it is empty .
* For example :
2014-11-24 00:39:22 -05:00
*
* if ( ! empty ( $deprecated ) ) {
2016-07-06 08:40:29 -04:00
* _deprecated_argument ( __FUNCTION__ , '3.0.0' );
2014-11-24 00:39:22 -05:00
* }
*
2009-12-24 06:06:00 -05:00
* There is a hook deprecated_argument_run that will be called that can be used
* to get the backtrace up to what file and function used the deprecated
* argument .
*
2010-12-15 07:09:53 -05:00
* The current behavior is to trigger a user error if WP_DEBUG is true .
2009-12-24 06:06:00 -05:00
*
* @ since 3.0 . 0
2019-10-27 10:21:03 -04:00
* @ since 5.4 . 0 This function is no longer marked as " private " .
2019-10-31 20:41:01 -04:00
* @ since 5.4 . 0 The error type is now classified as E_USER_DEPRECATED ( used to default to E_USER_NOTICE ) .
2009-12-24 06:06:00 -05:00
*
Code Modernization: Rename parameters that use reserved keywords in `wp-includes/functions.php`.
While using reserved PHP keywords as parameter name labels is allowed, in the context of function calls using named parameters in PHP 8.0+, this will easily lead to confusion. To avoid that, it is recommended not to use reserved keywords as function parameter names.
This commit:
* Renames the `$echo` parameter to `$display` in:
* `wp_nonce_field()`
* `wp_referer_field()`
* `wp_original_referer_field()`
* Renames the `$string` parameter to `$input_string` in
* `_wp_json_convert_string()`
* `_wp_to_kebab_case()`
* Renames the `$list` parameter to `$input_list` in:
* `wp_parse_list()`
* `wp_parse_id_list()`
* `wp_parse_slug_list()`
* `wp_filter_object_list()`
* `wp_list_filter()`
* `wp_list_pluck()`
* `wp_list_sort()`
* Renames the `$array` parameter to `$input_array` in:
* `add_magic_quotes()`
* `wp_array_slice_assoc()`
* `_wp_array_get()`
* `_wp_array_set()`
* Renames the `$function` parameter to `$function_name` in:
* `_deprecated_function()`
* `_deprecated_argument()`
* `_doing_it_wrong()`
* Renames the `$class` parameter to `$class_name` in `_deprecated_constructor()`.
* Renames the `$default` parameter to `$default_value` in `apache_mod_loaded()`.
* Renames the `$var` parameter to `$value` in `wp_validate_boolean()`.
* Amends the `$input` parameter in `wp_parse_str()` for consistency.
Follow-up to [52946], [52996], [52997], [52998], [53003], [53014], [53029], [53039], [53116], [53117], [53137], [53174], [53184], [53185], [53192], [53193], [53198], [53203], [53207], [53215], [53216], [53220], [53230], [53232], [53236], [53239], [53240], [53242], [53243], [53245], [53246], [53257], [53269], [53270], [53271], [53272], [53273], [53274], [53275], [53276], [53277], [53281], [53283], [53284], [53285], [53287], [53364], [53365], [54927].
Props jrf, aristath, poena, justinahinon, SergeyBiryukov.
See #56788.
Built from https://develop.svn.wordpress.org/trunk@54929
git-svn-id: http://core.svn.wordpress.org/trunk@54481 1a063a9b-81f0-0310-95a4-ce76da25c4cd
2022-12-03 10:07:14 -05:00
* @ param string $function_name The function that was called .
* @ param string $version The version of WordPress that deprecated the argument used .
2023-02-21 11:39:19 -05:00
* @ param string $message Optional . A message regarding the change . Default empty string .
2009-12-24 06:06:00 -05:00
*/
Code Modernization: Rename parameters that use reserved keywords in `wp-includes/functions.php`.
While using reserved PHP keywords as parameter name labels is allowed, in the context of function calls using named parameters in PHP 8.0+, this will easily lead to confusion. To avoid that, it is recommended not to use reserved keywords as function parameter names.
This commit:
* Renames the `$echo` parameter to `$display` in:
* `wp_nonce_field()`
* `wp_referer_field()`
* `wp_original_referer_field()`
* Renames the `$string` parameter to `$input_string` in
* `_wp_json_convert_string()`
* `_wp_to_kebab_case()`
* Renames the `$list` parameter to `$input_list` in:
* `wp_parse_list()`
* `wp_parse_id_list()`
* `wp_parse_slug_list()`
* `wp_filter_object_list()`
* `wp_list_filter()`
* `wp_list_pluck()`
* `wp_list_sort()`
* Renames the `$array` parameter to `$input_array` in:
* `add_magic_quotes()`
* `wp_array_slice_assoc()`
* `_wp_array_get()`
* `_wp_array_set()`
* Renames the `$function` parameter to `$function_name` in:
* `_deprecated_function()`
* `_deprecated_argument()`
* `_doing_it_wrong()`
* Renames the `$class` parameter to `$class_name` in `_deprecated_constructor()`.
* Renames the `$default` parameter to `$default_value` in `apache_mod_loaded()`.
* Renames the `$var` parameter to `$value` in `wp_validate_boolean()`.
* Amends the `$input` parameter in `wp_parse_str()` for consistency.
Follow-up to [52946], [52996], [52997], [52998], [53003], [53014], [53029], [53039], [53116], [53117], [53137], [53174], [53184], [53185], [53192], [53193], [53198], [53203], [53207], [53215], [53216], [53220], [53230], [53232], [53236], [53239], [53240], [53242], [53243], [53245], [53246], [53257], [53269], [53270], [53271], [53272], [53273], [53274], [53275], [53276], [53277], [53281], [53283], [53284], [53285], [53287], [53364], [53365], [54927].
Props jrf, aristath, poena, justinahinon, SergeyBiryukov.
See #56788.
Built from https://develop.svn.wordpress.org/trunk@54929
git-svn-id: http://core.svn.wordpress.org/trunk@54481 1a063a9b-81f0-0310-95a4-ce76da25c4cd
2022-12-03 10:07:14 -05:00
function _deprecated_argument ( $function_name , $version , $message = '' ) {
2009-12-24 06:06:00 -05:00
2014-04-13 20:20:14 -04:00
/**
* Fires when a deprecated argument is called .
*
* @ since 3.0 . 0
*
Code Modernization: Rename parameters that use reserved keywords in `wp-includes/functions.php`.
While using reserved PHP keywords as parameter name labels is allowed, in the context of function calls using named parameters in PHP 8.0+, this will easily lead to confusion. To avoid that, it is recommended not to use reserved keywords as function parameter names.
This commit:
* Renames the `$echo` parameter to `$display` in:
* `wp_nonce_field()`
* `wp_referer_field()`
* `wp_original_referer_field()`
* Renames the `$string` parameter to `$input_string` in
* `_wp_json_convert_string()`
* `_wp_to_kebab_case()`
* Renames the `$list` parameter to `$input_list` in:
* `wp_parse_list()`
* `wp_parse_id_list()`
* `wp_parse_slug_list()`
* `wp_filter_object_list()`
* `wp_list_filter()`
* `wp_list_pluck()`
* `wp_list_sort()`
* Renames the `$array` parameter to `$input_array` in:
* `add_magic_quotes()`
* `wp_array_slice_assoc()`
* `_wp_array_get()`
* `_wp_array_set()`
* Renames the `$function` parameter to `$function_name` in:
* `_deprecated_function()`
* `_deprecated_argument()`
* `_doing_it_wrong()`
* Renames the `$class` parameter to `$class_name` in `_deprecated_constructor()`.
* Renames the `$default` parameter to `$default_value` in `apache_mod_loaded()`.
* Renames the `$var` parameter to `$value` in `wp_validate_boolean()`.
* Amends the `$input` parameter in `wp_parse_str()` for consistency.
Follow-up to [52946], [52996], [52997], [52998], [53003], [53014], [53029], [53039], [53116], [53117], [53137], [53174], [53184], [53185], [53192], [53193], [53198], [53203], [53207], [53215], [53216], [53220], [53230], [53232], [53236], [53239], [53240], [53242], [53243], [53245], [53246], [53257], [53269], [53270], [53271], [53272], [53273], [53274], [53275], [53276], [53277], [53281], [53283], [53284], [53285], [53287], [53364], [53365], [54927].
Props jrf, aristath, poena, justinahinon, SergeyBiryukov.
See #56788.
Built from https://develop.svn.wordpress.org/trunk@54929
git-svn-id: http://core.svn.wordpress.org/trunk@54481 1a063a9b-81f0-0310-95a4-ce76da25c4cd
2022-12-03 10:07:14 -05:00
* @ param string $function_name The function that was called .
* @ param string $message A message regarding the change .
* @ param string $version The version of WordPress that deprecated the argument used .
2014-04-13 20:20:14 -04:00
*/
Code Modernization: Rename parameters that use reserved keywords in `wp-includes/functions.php`.
While using reserved PHP keywords as parameter name labels is allowed, in the context of function calls using named parameters in PHP 8.0+, this will easily lead to confusion. To avoid that, it is recommended not to use reserved keywords as function parameter names.
This commit:
* Renames the `$echo` parameter to `$display` in:
* `wp_nonce_field()`
* `wp_referer_field()`
* `wp_original_referer_field()`
* Renames the `$string` parameter to `$input_string` in
* `_wp_json_convert_string()`
* `_wp_to_kebab_case()`
* Renames the `$list` parameter to `$input_list` in:
* `wp_parse_list()`
* `wp_parse_id_list()`
* `wp_parse_slug_list()`
* `wp_filter_object_list()`
* `wp_list_filter()`
* `wp_list_pluck()`
* `wp_list_sort()`
* Renames the `$array` parameter to `$input_array` in:
* `add_magic_quotes()`
* `wp_array_slice_assoc()`
* `_wp_array_get()`
* `_wp_array_set()`
* Renames the `$function` parameter to `$function_name` in:
* `_deprecated_function()`
* `_deprecated_argument()`
* `_doing_it_wrong()`
* Renames the `$class` parameter to `$class_name` in `_deprecated_constructor()`.
* Renames the `$default` parameter to `$default_value` in `apache_mod_loaded()`.
* Renames the `$var` parameter to `$value` in `wp_validate_boolean()`.
* Amends the `$input` parameter in `wp_parse_str()` for consistency.
Follow-up to [52946], [52996], [52997], [52998], [53003], [53014], [53029], [53039], [53116], [53117], [53137], [53174], [53184], [53185], [53192], [53193], [53198], [53203], [53207], [53215], [53216], [53220], [53230], [53232], [53236], [53239], [53240], [53242], [53243], [53245], [53246], [53257], [53269], [53270], [53271], [53272], [53273], [53274], [53275], [53276], [53277], [53281], [53283], [53284], [53285], [53287], [53364], [53365], [54927].
Props jrf, aristath, poena, justinahinon, SergeyBiryukov.
See #56788.
Built from https://develop.svn.wordpress.org/trunk@54929
git-svn-id: http://core.svn.wordpress.org/trunk@54481 1a063a9b-81f0-0310-95a4-ce76da25c4cd
2022-12-03 10:07:14 -05:00
do_action ( 'deprecated_argument_run' , $function_name , $message , $version );
2009-12-24 06:06:00 -05:00
2014-04-13 20:20:14 -04:00
/**
2016-05-22 14:36:27 -04:00
* Filters whether to trigger an error for deprecated arguments .
2014-04-13 20:20:14 -04:00
*
* @ since 3.0 . 0
*
* @ param bool $trigger Whether to trigger the error for deprecated arguments . Default true .
*/
2010-01-09 05:03:55 -05:00
if ( WP_DEBUG && apply_filters ( 'deprecated_argument_trigger_error' , true ) ) {
2013-07-17 17:04:50 -04:00
if ( function_exists ( '__' ) ) {
2020-07-05 17:09:03 -04:00
if ( $message ) {
2019-10-31 20:41:01 -04:00
trigger_error (
sprintf (
/* translators: 1: PHP function name, 2: Version number, 3: Optional message regarding the change. */
General: Clarify the deprecation messages in the `_deprecated_*()` functions family.
This makes the strings easier to translate and provides more details about what exactly is deprecated: a PHP function, a file name, or a WordPress hook.
The changes apply to:
* `_deprecated_function()`
* `_deprecated_constructor()`
* `_deprecated_file()`
* `_deprecated_argument()`
* `_deprecated_hook()`
* `_doing_it_wrong()`
Follow-up to [6514], [7884], [12536], [12584], [16939], [16942], [16945], [24439], [24723], [32989], [37861], [39315].
Props mukesh27, audrasjb, SergeyBiryukov.
Fixes #54658.
Built from https://develop.svn.wordpress.org/trunk@52609
git-svn-id: http://core.svn.wordpress.org/trunk@52197 1a063a9b-81f0-0310-95a4-ce76da25c4cd
2022-01-20 08:13:01 -05:00
__ ( 'Function %1$s was called with an argument that is <strong>deprecated</strong> since version %2$s! %3$s' ),
Code Modernization: Rename parameters that use reserved keywords in `wp-includes/functions.php`.
While using reserved PHP keywords as parameter name labels is allowed, in the context of function calls using named parameters in PHP 8.0+, this will easily lead to confusion. To avoid that, it is recommended not to use reserved keywords as function parameter names.
This commit:
* Renames the `$echo` parameter to `$display` in:
* `wp_nonce_field()`
* `wp_referer_field()`
* `wp_original_referer_field()`
* Renames the `$string` parameter to `$input_string` in
* `_wp_json_convert_string()`
* `_wp_to_kebab_case()`
* Renames the `$list` parameter to `$input_list` in:
* `wp_parse_list()`
* `wp_parse_id_list()`
* `wp_parse_slug_list()`
* `wp_filter_object_list()`
* `wp_list_filter()`
* `wp_list_pluck()`
* `wp_list_sort()`
* Renames the `$array` parameter to `$input_array` in:
* `add_magic_quotes()`
* `wp_array_slice_assoc()`
* `_wp_array_get()`
* `_wp_array_set()`
* Renames the `$function` parameter to `$function_name` in:
* `_deprecated_function()`
* `_deprecated_argument()`
* `_doing_it_wrong()`
* Renames the `$class` parameter to `$class_name` in `_deprecated_constructor()`.
* Renames the `$default` parameter to `$default_value` in `apache_mod_loaded()`.
* Renames the `$var` parameter to `$value` in `wp_validate_boolean()`.
* Amends the `$input` parameter in `wp_parse_str()` for consistency.
Follow-up to [52946], [52996], [52997], [52998], [53003], [53014], [53029], [53039], [53116], [53117], [53137], [53174], [53184], [53185], [53192], [53193], [53198], [53203], [53207], [53215], [53216], [53220], [53230], [53232], [53236], [53239], [53240], [53242], [53243], [53245], [53246], [53257], [53269], [53270], [53271], [53272], [53273], [53274], [53275], [53276], [53277], [53281], [53283], [53284], [53285], [53287], [53364], [53365], [54927].
Props jrf, aristath, poena, justinahinon, SergeyBiryukov.
See #56788.
Built from https://develop.svn.wordpress.org/trunk@54929
git-svn-id: http://core.svn.wordpress.org/trunk@54481 1a063a9b-81f0-0310-95a4-ce76da25c4cd
2022-12-03 10:07:14 -05:00
$function_name ,
2019-10-31 20:41:01 -04:00
$version ,
$message
),
E_USER_DEPRECATED
);
2016-11-18 21:39:33 -05:00
} else {
2019-10-31 20:41:01 -04:00
trigger_error (
sprintf (
/* translators: 1: PHP function name, 2: Version number. */
General: Clarify the deprecation messages in the `_deprecated_*()` functions family.
This makes the strings easier to translate and provides more details about what exactly is deprecated: a PHP function, a file name, or a WordPress hook.
The changes apply to:
* `_deprecated_function()`
* `_deprecated_constructor()`
* `_deprecated_file()`
* `_deprecated_argument()`
* `_deprecated_hook()`
* `_doing_it_wrong()`
Follow-up to [6514], [7884], [12536], [12584], [16939], [16942], [16945], [24439], [24723], [32989], [37861], [39315].
Props mukesh27, audrasjb, SergeyBiryukov.
Fixes #54658.
Built from https://develop.svn.wordpress.org/trunk@52609
git-svn-id: http://core.svn.wordpress.org/trunk@52197 1a063a9b-81f0-0310-95a4-ce76da25c4cd
2022-01-20 08:13:01 -05:00
__ ( 'Function %1$s was called with an argument that is <strong>deprecated</strong> since version %2$s with no alternative available.' ),
Code Modernization: Rename parameters that use reserved keywords in `wp-includes/functions.php`.
While using reserved PHP keywords as parameter name labels is allowed, in the context of function calls using named parameters in PHP 8.0+, this will easily lead to confusion. To avoid that, it is recommended not to use reserved keywords as function parameter names.
This commit:
* Renames the `$echo` parameter to `$display` in:
* `wp_nonce_field()`
* `wp_referer_field()`
* `wp_original_referer_field()`
* Renames the `$string` parameter to `$input_string` in
* `_wp_json_convert_string()`
* `_wp_to_kebab_case()`
* Renames the `$list` parameter to `$input_list` in:
* `wp_parse_list()`
* `wp_parse_id_list()`
* `wp_parse_slug_list()`
* `wp_filter_object_list()`
* `wp_list_filter()`
* `wp_list_pluck()`
* `wp_list_sort()`
* Renames the `$array` parameter to `$input_array` in:
* `add_magic_quotes()`
* `wp_array_slice_assoc()`
* `_wp_array_get()`
* `_wp_array_set()`
* Renames the `$function` parameter to `$function_name` in:
* `_deprecated_function()`
* `_deprecated_argument()`
* `_doing_it_wrong()`
* Renames the `$class` parameter to `$class_name` in `_deprecated_constructor()`.
* Renames the `$default` parameter to `$default_value` in `apache_mod_loaded()`.
* Renames the `$var` parameter to `$value` in `wp_validate_boolean()`.
* Amends the `$input` parameter in `wp_parse_str()` for consistency.
Follow-up to [52946], [52996], [52997], [52998], [53003], [53014], [53029], [53039], [53116], [53117], [53137], [53174], [53184], [53185], [53192], [53193], [53198], [53203], [53207], [53215], [53216], [53220], [53230], [53232], [53236], [53239], [53240], [53242], [53243], [53245], [53246], [53257], [53269], [53270], [53271], [53272], [53273], [53274], [53275], [53276], [53277], [53281], [53283], [53284], [53285], [53287], [53364], [53365], [54927].
Props jrf, aristath, poena, justinahinon, SergeyBiryukov.
See #56788.
Built from https://develop.svn.wordpress.org/trunk@54929
git-svn-id: http://core.svn.wordpress.org/trunk@54481 1a063a9b-81f0-0310-95a4-ce76da25c4cd
2022-12-03 10:07:14 -05:00
$function_name ,
2019-10-31 20:41:01 -04:00
$version
),
E_USER_DEPRECATED
);
2016-11-18 21:39:33 -05:00
}
2013-07-17 17:04:50 -04:00
} else {
2020-07-05 17:09:03 -04:00
if ( $message ) {
2019-10-31 20:41:01 -04:00
trigger_error (
sprintf (
General: Clarify the deprecation messages in the `_deprecated_*()` functions family.
This makes the strings easier to translate and provides more details about what exactly is deprecated: a PHP function, a file name, or a WordPress hook.
The changes apply to:
* `_deprecated_function()`
* `_deprecated_constructor()`
* `_deprecated_file()`
* `_deprecated_argument()`
* `_deprecated_hook()`
* `_doing_it_wrong()`
Follow-up to [6514], [7884], [12536], [12584], [16939], [16942], [16945], [24439], [24723], [32989], [37861], [39315].
Props mukesh27, audrasjb, SergeyBiryukov.
Fixes #54658.
Built from https://develop.svn.wordpress.org/trunk@52609
git-svn-id: http://core.svn.wordpress.org/trunk@52197 1a063a9b-81f0-0310-95a4-ce76da25c4cd
2022-01-20 08:13:01 -05:00
'Function %1$s was called with an argument that is <strong>deprecated</strong> since version %2$s! %3$s' ,
Code Modernization: Rename parameters that use reserved keywords in `wp-includes/functions.php`.
While using reserved PHP keywords as parameter name labels is allowed, in the context of function calls using named parameters in PHP 8.0+, this will easily lead to confusion. To avoid that, it is recommended not to use reserved keywords as function parameter names.
This commit:
* Renames the `$echo` parameter to `$display` in:
* `wp_nonce_field()`
* `wp_referer_field()`
* `wp_original_referer_field()`
* Renames the `$string` parameter to `$input_string` in
* `_wp_json_convert_string()`
* `_wp_to_kebab_case()`
* Renames the `$list` parameter to `$input_list` in:
* `wp_parse_list()`
* `wp_parse_id_list()`
* `wp_parse_slug_list()`
* `wp_filter_object_list()`
* `wp_list_filter()`
* `wp_list_pluck()`
* `wp_list_sort()`
* Renames the `$array` parameter to `$input_array` in:
* `add_magic_quotes()`
* `wp_array_slice_assoc()`
* `_wp_array_get()`
* `_wp_array_set()`
* Renames the `$function` parameter to `$function_name` in:
* `_deprecated_function()`
* `_deprecated_argument()`
* `_doing_it_wrong()`
* Renames the `$class` parameter to `$class_name` in `_deprecated_constructor()`.
* Renames the `$default` parameter to `$default_value` in `apache_mod_loaded()`.
* Renames the `$var` parameter to `$value` in `wp_validate_boolean()`.
* Amends the `$input` parameter in `wp_parse_str()` for consistency.
Follow-up to [52946], [52996], [52997], [52998], [53003], [53014], [53029], [53039], [53116], [53117], [53137], [53174], [53184], [53185], [53192], [53193], [53198], [53203], [53207], [53215], [53216], [53220], [53230], [53232], [53236], [53239], [53240], [53242], [53243], [53245], [53246], [53257], [53269], [53270], [53271], [53272], [53273], [53274], [53275], [53276], [53277], [53281], [53283], [53284], [53285], [53287], [53364], [53365], [54927].
Props jrf, aristath, poena, justinahinon, SergeyBiryukov.
See #56788.
Built from https://develop.svn.wordpress.org/trunk@54929
git-svn-id: http://core.svn.wordpress.org/trunk@54481 1a063a9b-81f0-0310-95a4-ce76da25c4cd
2022-12-03 10:07:14 -05:00
$function_name ,
2019-10-31 20:41:01 -04:00
$version ,
$message
),
E_USER_DEPRECATED
);
2016-11-18 21:39:33 -05:00
} else {
2019-10-31 20:41:01 -04:00
trigger_error (
sprintf (
General: Clarify the deprecation messages in the `_deprecated_*()` functions family.
This makes the strings easier to translate and provides more details about what exactly is deprecated: a PHP function, a file name, or a WordPress hook.
The changes apply to:
* `_deprecated_function()`
* `_deprecated_constructor()`
* `_deprecated_file()`
* `_deprecated_argument()`
* `_deprecated_hook()`
* `_doing_it_wrong()`
Follow-up to [6514], [7884], [12536], [12584], [16939], [16942], [16945], [24439], [24723], [32989], [37861], [39315].
Props mukesh27, audrasjb, SergeyBiryukov.
Fixes #54658.
Built from https://develop.svn.wordpress.org/trunk@52609
git-svn-id: http://core.svn.wordpress.org/trunk@52197 1a063a9b-81f0-0310-95a4-ce76da25c4cd
2022-01-20 08:13:01 -05:00
'Function %1$s was called with an argument that is <strong>deprecated</strong> since version %2$s with no alternative available.' ,
Code Modernization: Rename parameters that use reserved keywords in `wp-includes/functions.php`.
While using reserved PHP keywords as parameter name labels is allowed, in the context of function calls using named parameters in PHP 8.0+, this will easily lead to confusion. To avoid that, it is recommended not to use reserved keywords as function parameter names.
This commit:
* Renames the `$echo` parameter to `$display` in:
* `wp_nonce_field()`
* `wp_referer_field()`
* `wp_original_referer_field()`
* Renames the `$string` parameter to `$input_string` in
* `_wp_json_convert_string()`
* `_wp_to_kebab_case()`
* Renames the `$list` parameter to `$input_list` in:
* `wp_parse_list()`
* `wp_parse_id_list()`
* `wp_parse_slug_list()`
* `wp_filter_object_list()`
* `wp_list_filter()`
* `wp_list_pluck()`
* `wp_list_sort()`
* Renames the `$array` parameter to `$input_array` in:
* `add_magic_quotes()`
* `wp_array_slice_assoc()`
* `_wp_array_get()`
* `_wp_array_set()`
* Renames the `$function` parameter to `$function_name` in:
* `_deprecated_function()`
* `_deprecated_argument()`
* `_doing_it_wrong()`
* Renames the `$class` parameter to `$class_name` in `_deprecated_constructor()`.
* Renames the `$default` parameter to `$default_value` in `apache_mod_loaded()`.
* Renames the `$var` parameter to `$value` in `wp_validate_boolean()`.
* Amends the `$input` parameter in `wp_parse_str()` for consistency.
Follow-up to [52946], [52996], [52997], [52998], [53003], [53014], [53029], [53039], [53116], [53117], [53137], [53174], [53184], [53185], [53192], [53193], [53198], [53203], [53207], [53215], [53216], [53220], [53230], [53232], [53236], [53239], [53240], [53242], [53243], [53245], [53246], [53257], [53269], [53270], [53271], [53272], [53273], [53274], [53275], [53276], [53277], [53281], [53283], [53284], [53285], [53287], [53364], [53365], [54927].
Props jrf, aristath, poena, justinahinon, SergeyBiryukov.
See #56788.
Built from https://develop.svn.wordpress.org/trunk@54929
git-svn-id: http://core.svn.wordpress.org/trunk@54481 1a063a9b-81f0-0310-95a4-ce76da25c4cd
2022-12-03 10:07:14 -05:00
$function_name ,
2019-10-31 20:41:01 -04:00
$version
),
E_USER_DEPRECATED
);
2016-11-18 21:39:33 -05:00
}
2013-07-17 17:04:50 -04:00
}
2009-12-24 06:06:00 -05:00
}
}
2008-03-19 20:33:59 -04:00
2016-06-26 10:26:29 -04:00
/**
* Marks a deprecated action or filter hook as deprecated and throws a notice .
*
2016-07-20 12:57:32 -04:00
* Use the { @ see 'deprecated_hook_run' } action to get the backtrace describing where
* the deprecated hook was called .
2016-06-26 10:26:29 -04:00
*
2016-07-20 12:57:32 -04:00
* Default behavior is to trigger a user error if `WP_DEBUG` is true .
2016-06-26 10:26:29 -04:00
*
* This function is called by the do_action_deprecated () and apply_filters_deprecated ()
* functions , and so generally does not need to be called directly .
*
* @ since 4.6 . 0
2019-10-31 20:41:01 -04:00
* @ since 5.4 . 0 The error type is now classified as E_USER_DEPRECATED ( used to default to E_USER_NOTICE ) .
2016-06-26 10:26:29 -04:00
* @ access private
*
* @ param string $hook The hook that was used .
* @ param string $version The version of WordPress that deprecated the hook .
2023-02-21 11:39:19 -05:00
* @ param string $replacement Optional . The hook that should have been used . Default empty string .
2020-07-05 17:09:03 -04:00
* @ param string $message Optional . A message regarding the change . Default empty .
2016-06-26 10:26:29 -04:00
*/
2020-07-05 17:09:03 -04:00
function _deprecated_hook ( $hook , $version , $replacement = '' , $message = '' ) {
2016-06-26 10:26:29 -04:00
/**
* Fires when a deprecated hook is called .
*
* @ since 4.6 . 0
*
* @ param string $hook The hook that was called .
* @ param string $replacement The hook that should be used as a replacement .
* @ param string $version The version of WordPress that deprecated the argument used .
* @ param string $message A message regarding the change .
*/
do_action ( 'deprecated_hook_run' , $hook , $replacement , $version , $message );
/**
2016-07-20 12:57:32 -04:00
* Filters whether to trigger deprecated hook errors .
2016-06-26 10:26:29 -04:00
*
* @ since 4.6 . 0
*
* @ param bool $trigger Whether to trigger deprecated hook errors . Requires
* `WP_DEBUG` to be defined true .
*/
if ( WP_DEBUG && apply_filters ( 'deprecated_hook_trigger_error' , true ) ) {
$message = empty ( $message ) ? '' : ' ' . $message ;
2019-10-31 20:41:01 -04:00
2020-07-05 17:09:03 -04:00
if ( $replacement ) {
2019-10-31 20:41:01 -04:00
trigger_error (
sprintf (
/* translators: 1: WordPress hook name, 2: Version number, 3: Alternative hook name. */
General: Clarify the deprecation messages in the `_deprecated_*()` functions family.
This makes the strings easier to translate and provides more details about what exactly is deprecated: a PHP function, a file name, or a WordPress hook.
The changes apply to:
* `_deprecated_function()`
* `_deprecated_constructor()`
* `_deprecated_file()`
* `_deprecated_argument()`
* `_deprecated_hook()`
* `_doing_it_wrong()`
Follow-up to [6514], [7884], [12536], [12584], [16939], [16942], [16945], [24439], [24723], [32989], [37861], [39315].
Props mukesh27, audrasjb, SergeyBiryukov.
Fixes #54658.
Built from https://develop.svn.wordpress.org/trunk@52609
git-svn-id: http://core.svn.wordpress.org/trunk@52197 1a063a9b-81f0-0310-95a4-ce76da25c4cd
2022-01-20 08:13:01 -05:00
__ ( 'Hook %1$s is <strong>deprecated</strong> since version %2$s! Use %3$s instead.' ),
2019-10-31 20:41:01 -04:00
$hook ,
$version ,
$replacement
) . $message ,
E_USER_DEPRECATED
);
2016-06-26 10:26:29 -04:00
} else {
2019-10-31 20:41:01 -04:00
trigger_error (
sprintf (
/* translators: 1: WordPress hook name, 2: Version number. */
General: Clarify the deprecation messages in the `_deprecated_*()` functions family.
This makes the strings easier to translate and provides more details about what exactly is deprecated: a PHP function, a file name, or a WordPress hook.
The changes apply to:
* `_deprecated_function()`
* `_deprecated_constructor()`
* `_deprecated_file()`
* `_deprecated_argument()`
* `_deprecated_hook()`
* `_doing_it_wrong()`
Follow-up to [6514], [7884], [12536], [12584], [16939], [16942], [16945], [24439], [24723], [32989], [37861], [39315].
Props mukesh27, audrasjb, SergeyBiryukov.
Fixes #54658.
Built from https://develop.svn.wordpress.org/trunk@52609
git-svn-id: http://core.svn.wordpress.org/trunk@52197 1a063a9b-81f0-0310-95a4-ce76da25c4cd
2022-01-20 08:13:01 -05:00
__ ( 'Hook %1$s is <strong>deprecated</strong> since version %2$s with no alternative available.' ),
2019-10-31 20:41:01 -04:00
$hook ,
$version
) . $message ,
E_USER_DEPRECATED
);
2016-06-26 10:26:29 -04:00
}
}
}
2010-12-15 07:06:39 -05:00
/**
2022-08-12 05:53:11 -04:00
* Marks something as being incorrectly called .
2010-12-15 07:06:39 -05:00
*
2016-05-23 15:01:27 -04:00
* There is a hook { @ see 'doing_it_wrong_run' } that will be called that can be used
2010-12-15 07:06:39 -05:00
* to get the backtrace up to what file and function called the deprecated
* function .
*
2016-05-23 15:01:27 -04:00
* The current behavior is to trigger a user error if `WP_DEBUG` is true .
2010-12-15 07:06:39 -05:00
*
* @ since 3.1 . 0
2019-10-27 10:21:03 -04:00
* @ since 5.4 . 0 This function is no longer marked as " private " .
2010-12-15 07:06:39 -05:00
*
Code Modernization: Rename parameters that use reserved keywords in `wp-includes/functions.php`.
While using reserved PHP keywords as parameter name labels is allowed, in the context of function calls using named parameters in PHP 8.0+, this will easily lead to confusion. To avoid that, it is recommended not to use reserved keywords as function parameter names.
This commit:
* Renames the `$echo` parameter to `$display` in:
* `wp_nonce_field()`
* `wp_referer_field()`
* `wp_original_referer_field()`
* Renames the `$string` parameter to `$input_string` in
* `_wp_json_convert_string()`
* `_wp_to_kebab_case()`
* Renames the `$list` parameter to `$input_list` in:
* `wp_parse_list()`
* `wp_parse_id_list()`
* `wp_parse_slug_list()`
* `wp_filter_object_list()`
* `wp_list_filter()`
* `wp_list_pluck()`
* `wp_list_sort()`
* Renames the `$array` parameter to `$input_array` in:
* `add_magic_quotes()`
* `wp_array_slice_assoc()`
* `_wp_array_get()`
* `_wp_array_set()`
* Renames the `$function` parameter to `$function_name` in:
* `_deprecated_function()`
* `_deprecated_argument()`
* `_doing_it_wrong()`
* Renames the `$class` parameter to `$class_name` in `_deprecated_constructor()`.
* Renames the `$default` parameter to `$default_value` in `apache_mod_loaded()`.
* Renames the `$var` parameter to `$value` in `wp_validate_boolean()`.
* Amends the `$input` parameter in `wp_parse_str()` for consistency.
Follow-up to [52946], [52996], [52997], [52998], [53003], [53014], [53029], [53039], [53116], [53117], [53137], [53174], [53184], [53185], [53192], [53193], [53198], [53203], [53207], [53215], [53216], [53220], [53230], [53232], [53236], [53239], [53240], [53242], [53243], [53245], [53246], [53257], [53269], [53270], [53271], [53272], [53273], [53274], [53275], [53276], [53277], [53281], [53283], [53284], [53285], [53287], [53364], [53365], [54927].
Props jrf, aristath, poena, justinahinon, SergeyBiryukov.
See #56788.
Built from https://develop.svn.wordpress.org/trunk@54929
git-svn-id: http://core.svn.wordpress.org/trunk@54481 1a063a9b-81f0-0310-95a4-ce76da25c4cd
2022-12-03 10:07:14 -05:00
* @ param string $function_name The function that was called .
* @ param string $message A message explaining what has been done incorrectly .
* @ param string $version The version of WordPress where the message was added .
2010-12-15 07:06:39 -05:00
*/
Code Modernization: Rename parameters that use reserved keywords in `wp-includes/functions.php`.
While using reserved PHP keywords as parameter name labels is allowed, in the context of function calls using named parameters in PHP 8.0+, this will easily lead to confusion. To avoid that, it is recommended not to use reserved keywords as function parameter names.
This commit:
* Renames the `$echo` parameter to `$display` in:
* `wp_nonce_field()`
* `wp_referer_field()`
* `wp_original_referer_field()`
* Renames the `$string` parameter to `$input_string` in
* `_wp_json_convert_string()`
* `_wp_to_kebab_case()`
* Renames the `$list` parameter to `$input_list` in:
* `wp_parse_list()`
* `wp_parse_id_list()`
* `wp_parse_slug_list()`
* `wp_filter_object_list()`
* `wp_list_filter()`
* `wp_list_pluck()`
* `wp_list_sort()`
* Renames the `$array` parameter to `$input_array` in:
* `add_magic_quotes()`
* `wp_array_slice_assoc()`
* `_wp_array_get()`
* `_wp_array_set()`
* Renames the `$function` parameter to `$function_name` in:
* `_deprecated_function()`
* `_deprecated_argument()`
* `_doing_it_wrong()`
* Renames the `$class` parameter to `$class_name` in `_deprecated_constructor()`.
* Renames the `$default` parameter to `$default_value` in `apache_mod_loaded()`.
* Renames the `$var` parameter to `$value` in `wp_validate_boolean()`.
* Amends the `$input` parameter in `wp_parse_str()` for consistency.
Follow-up to [52946], [52996], [52997], [52998], [53003], [53014], [53029], [53039], [53116], [53117], [53137], [53174], [53184], [53185], [53192], [53193], [53198], [53203], [53207], [53215], [53216], [53220], [53230], [53232], [53236], [53239], [53240], [53242], [53243], [53245], [53246], [53257], [53269], [53270], [53271], [53272], [53273], [53274], [53275], [53276], [53277], [53281], [53283], [53284], [53285], [53287], [53364], [53365], [54927].
Props jrf, aristath, poena, justinahinon, SergeyBiryukov.
See #56788.
Built from https://develop.svn.wordpress.org/trunk@54929
git-svn-id: http://core.svn.wordpress.org/trunk@54481 1a063a9b-81f0-0310-95a4-ce76da25c4cd
2022-12-03 10:07:14 -05:00
function _doing_it_wrong ( $function_name , $message , $version ) {
2010-12-15 07:06:39 -05:00
2014-04-13 20:20:14 -04:00
/**
* Fires when the given function is being used incorrectly .
*
* @ since 3.1 . 0
*
Code Modernization: Rename parameters that use reserved keywords in `wp-includes/functions.php`.
While using reserved PHP keywords as parameter name labels is allowed, in the context of function calls using named parameters in PHP 8.0+, this will easily lead to confusion. To avoid that, it is recommended not to use reserved keywords as function parameter names.
This commit:
* Renames the `$echo` parameter to `$display` in:
* `wp_nonce_field()`
* `wp_referer_field()`
* `wp_original_referer_field()`
* Renames the `$string` parameter to `$input_string` in
* `_wp_json_convert_string()`
* `_wp_to_kebab_case()`
* Renames the `$list` parameter to `$input_list` in:
* `wp_parse_list()`
* `wp_parse_id_list()`
* `wp_parse_slug_list()`
* `wp_filter_object_list()`
* `wp_list_filter()`
* `wp_list_pluck()`
* `wp_list_sort()`
* Renames the `$array` parameter to `$input_array` in:
* `add_magic_quotes()`
* `wp_array_slice_assoc()`
* `_wp_array_get()`
* `_wp_array_set()`
* Renames the `$function` parameter to `$function_name` in:
* `_deprecated_function()`
* `_deprecated_argument()`
* `_doing_it_wrong()`
* Renames the `$class` parameter to `$class_name` in `_deprecated_constructor()`.
* Renames the `$default` parameter to `$default_value` in `apache_mod_loaded()`.
* Renames the `$var` parameter to `$value` in `wp_validate_boolean()`.
* Amends the `$input` parameter in `wp_parse_str()` for consistency.
Follow-up to [52946], [52996], [52997], [52998], [53003], [53014], [53029], [53039], [53116], [53117], [53137], [53174], [53184], [53185], [53192], [53193], [53198], [53203], [53207], [53215], [53216], [53220], [53230], [53232], [53236], [53239], [53240], [53242], [53243], [53245], [53246], [53257], [53269], [53270], [53271], [53272], [53273], [53274], [53275], [53276], [53277], [53281], [53283], [53284], [53285], [53287], [53364], [53365], [54927].
Props jrf, aristath, poena, justinahinon, SergeyBiryukov.
See #56788.
Built from https://develop.svn.wordpress.org/trunk@54929
git-svn-id: http://core.svn.wordpress.org/trunk@54481 1a063a9b-81f0-0310-95a4-ce76da25c4cd
2022-12-03 10:07:14 -05:00
* @ param string $function_name The function that was called .
* @ param string $message A message explaining what has been done incorrectly .
* @ param string $version The version of WordPress where the message was added .
2014-04-13 20:20:14 -04:00
*/
Code Modernization: Rename parameters that use reserved keywords in `wp-includes/functions.php`.
While using reserved PHP keywords as parameter name labels is allowed, in the context of function calls using named parameters in PHP 8.0+, this will easily lead to confusion. To avoid that, it is recommended not to use reserved keywords as function parameter names.
This commit:
* Renames the `$echo` parameter to `$display` in:
* `wp_nonce_field()`
* `wp_referer_field()`
* `wp_original_referer_field()`
* Renames the `$string` parameter to `$input_string` in
* `_wp_json_convert_string()`
* `_wp_to_kebab_case()`
* Renames the `$list` parameter to `$input_list` in:
* `wp_parse_list()`
* `wp_parse_id_list()`
* `wp_parse_slug_list()`
* `wp_filter_object_list()`
* `wp_list_filter()`
* `wp_list_pluck()`
* `wp_list_sort()`
* Renames the `$array` parameter to `$input_array` in:
* `add_magic_quotes()`
* `wp_array_slice_assoc()`
* `_wp_array_get()`
* `_wp_array_set()`
* Renames the `$function` parameter to `$function_name` in:
* `_deprecated_function()`
* `_deprecated_argument()`
* `_doing_it_wrong()`
* Renames the `$class` parameter to `$class_name` in `_deprecated_constructor()`.
* Renames the `$default` parameter to `$default_value` in `apache_mod_loaded()`.
* Renames the `$var` parameter to `$value` in `wp_validate_boolean()`.
* Amends the `$input` parameter in `wp_parse_str()` for consistency.
Follow-up to [52946], [52996], [52997], [52998], [53003], [53014], [53029], [53039], [53116], [53117], [53137], [53174], [53184], [53185], [53192], [53193], [53198], [53203], [53207], [53215], [53216], [53220], [53230], [53232], [53236], [53239], [53240], [53242], [53243], [53245], [53246], [53257], [53269], [53270], [53271], [53272], [53273], [53274], [53275], [53276], [53277], [53281], [53283], [53284], [53285], [53287], [53364], [53365], [54927].
Props jrf, aristath, poena, justinahinon, SergeyBiryukov.
See #56788.
Built from https://develop.svn.wordpress.org/trunk@54929
git-svn-id: http://core.svn.wordpress.org/trunk@54481 1a063a9b-81f0-0310-95a4-ce76da25c4cd
2022-12-03 10:07:14 -05:00
do_action ( 'doing_it_wrong_run' , $function_name , $message , $version );
2010-12-15 07:06:39 -05:00
2014-04-13 20:20:14 -04:00
/**
2016-05-22 14:36:27 -04:00
* Filters whether to trigger an error for _doing_it_wrong () calls .
2014-04-13 20:20:14 -04:00
*
* @ since 3.1 . 0
Code Modernization: Rename parameters that use reserved keywords in `wp-includes/functions.php`.
While using reserved PHP keywords as parameter name labels is allowed, in the context of function calls using named parameters in PHP 8.0+, this will easily lead to confusion. To avoid that, it is recommended not to use reserved keywords as function parameter names.
This commit:
* Renames the `$echo` parameter to `$display` in:
* `wp_nonce_field()`
* `wp_referer_field()`
* `wp_original_referer_field()`
* Renames the `$string` parameter to `$input_string` in
* `_wp_json_convert_string()`
* `_wp_to_kebab_case()`
* Renames the `$list` parameter to `$input_list` in:
* `wp_parse_list()`
* `wp_parse_id_list()`
* `wp_parse_slug_list()`
* `wp_filter_object_list()`
* `wp_list_filter()`
* `wp_list_pluck()`
* `wp_list_sort()`
* Renames the `$array` parameter to `$input_array` in:
* `add_magic_quotes()`
* `wp_array_slice_assoc()`
* `_wp_array_get()`
* `_wp_array_set()`
* Renames the `$function` parameter to `$function_name` in:
* `_deprecated_function()`
* `_deprecated_argument()`
* `_doing_it_wrong()`
* Renames the `$class` parameter to `$class_name` in `_deprecated_constructor()`.
* Renames the `$default` parameter to `$default_value` in `apache_mod_loaded()`.
* Renames the `$var` parameter to `$value` in `wp_validate_boolean()`.
* Amends the `$input` parameter in `wp_parse_str()` for consistency.
Follow-up to [52946], [52996], [52997], [52998], [53003], [53014], [53029], [53039], [53116], [53117], [53137], [53174], [53184], [53185], [53192], [53193], [53198], [53203], [53207], [53215], [53216], [53220], [53230], [53232], [53236], [53239], [53240], [53242], [53243], [53245], [53246], [53257], [53269], [53270], [53271], [53272], [53273], [53274], [53275], [53276], [53277], [53281], [53283], [53284], [53285], [53287], [53364], [53365], [54927].
Props jrf, aristath, poena, justinahinon, SergeyBiryukov.
See #56788.
Built from https://develop.svn.wordpress.org/trunk@54929
git-svn-id: http://core.svn.wordpress.org/trunk@54481 1a063a9b-81f0-0310-95a4-ce76da25c4cd
2022-12-03 10:07:14 -05:00
* @ since 5.1 . 0 Added the $function_name , $message and $version parameters .
2014-04-13 20:20:14 -04:00
*
Code Modernization: Rename parameters that use reserved keywords in `wp-includes/functions.php`.
While using reserved PHP keywords as parameter name labels is allowed, in the context of function calls using named parameters in PHP 8.0+, this will easily lead to confusion. To avoid that, it is recommended not to use reserved keywords as function parameter names.
This commit:
* Renames the `$echo` parameter to `$display` in:
* `wp_nonce_field()`
* `wp_referer_field()`
* `wp_original_referer_field()`
* Renames the `$string` parameter to `$input_string` in
* `_wp_json_convert_string()`
* `_wp_to_kebab_case()`
* Renames the `$list` parameter to `$input_list` in:
* `wp_parse_list()`
* `wp_parse_id_list()`
* `wp_parse_slug_list()`
* `wp_filter_object_list()`
* `wp_list_filter()`
* `wp_list_pluck()`
* `wp_list_sort()`
* Renames the `$array` parameter to `$input_array` in:
* `add_magic_quotes()`
* `wp_array_slice_assoc()`
* `_wp_array_get()`
* `_wp_array_set()`
* Renames the `$function` parameter to `$function_name` in:
* `_deprecated_function()`
* `_deprecated_argument()`
* `_doing_it_wrong()`
* Renames the `$class` parameter to `$class_name` in `_deprecated_constructor()`.
* Renames the `$default` parameter to `$default_value` in `apache_mod_loaded()`.
* Renames the `$var` parameter to `$value` in `wp_validate_boolean()`.
* Amends the `$input` parameter in `wp_parse_str()` for consistency.
Follow-up to [52946], [52996], [52997], [52998], [53003], [53014], [53029], [53039], [53116], [53117], [53137], [53174], [53184], [53185], [53192], [53193], [53198], [53203], [53207], [53215], [53216], [53220], [53230], [53232], [53236], [53239], [53240], [53242], [53243], [53245], [53246], [53257], [53269], [53270], [53271], [53272], [53273], [53274], [53275], [53276], [53277], [53281], [53283], [53284], [53285], [53287], [53364], [53365], [54927].
Props jrf, aristath, poena, justinahinon, SergeyBiryukov.
See #56788.
Built from https://develop.svn.wordpress.org/trunk@54929
git-svn-id: http://core.svn.wordpress.org/trunk@54481 1a063a9b-81f0-0310-95a4-ce76da25c4cd
2022-12-03 10:07:14 -05:00
* @ param bool $trigger Whether to trigger the error for _doing_it_wrong () calls . Default true .
* @ param string $function_name The function that was called .
* @ param string $message A message explaining what has been done incorrectly .
* @ param string $version The version of WordPress where the message was added .
2014-04-13 20:20:14 -04:00
*/
Code Modernization: Rename parameters that use reserved keywords in `wp-includes/functions.php`.
While using reserved PHP keywords as parameter name labels is allowed, in the context of function calls using named parameters in PHP 8.0+, this will easily lead to confusion. To avoid that, it is recommended not to use reserved keywords as function parameter names.
This commit:
* Renames the `$echo` parameter to `$display` in:
* `wp_nonce_field()`
* `wp_referer_field()`
* `wp_original_referer_field()`
* Renames the `$string` parameter to `$input_string` in
* `_wp_json_convert_string()`
* `_wp_to_kebab_case()`
* Renames the `$list` parameter to `$input_list` in:
* `wp_parse_list()`
* `wp_parse_id_list()`
* `wp_parse_slug_list()`
* `wp_filter_object_list()`
* `wp_list_filter()`
* `wp_list_pluck()`
* `wp_list_sort()`
* Renames the `$array` parameter to `$input_array` in:
* `add_magic_quotes()`
* `wp_array_slice_assoc()`
* `_wp_array_get()`
* `_wp_array_set()`
* Renames the `$function` parameter to `$function_name` in:
* `_deprecated_function()`
* `_deprecated_argument()`
* `_doing_it_wrong()`
* Renames the `$class` parameter to `$class_name` in `_deprecated_constructor()`.
* Renames the `$default` parameter to `$default_value` in `apache_mod_loaded()`.
* Renames the `$var` parameter to `$value` in `wp_validate_boolean()`.
* Amends the `$input` parameter in `wp_parse_str()` for consistency.
Follow-up to [52946], [52996], [52997], [52998], [53003], [53014], [53029], [53039], [53116], [53117], [53137], [53174], [53184], [53185], [53192], [53193], [53198], [53203], [53207], [53215], [53216], [53220], [53230], [53232], [53236], [53239], [53240], [53242], [53243], [53245], [53246], [53257], [53269], [53270], [53271], [53272], [53273], [53274], [53275], [53276], [53277], [53281], [53283], [53284], [53285], [53287], [53364], [53365], [54927].
Props jrf, aristath, poena, justinahinon, SergeyBiryukov.
See #56788.
Built from https://develop.svn.wordpress.org/trunk@54929
git-svn-id: http://core.svn.wordpress.org/trunk@54481 1a063a9b-81f0-0310-95a4-ce76da25c4cd
2022-12-03 10:07:14 -05:00
if ( WP_DEBUG && apply_filters ( 'doing_it_wrong_trigger_error' , true , $function_name , $message , $version ) ) {
2013-06-19 04:11:59 -04:00
if ( function_exists ( '__' ) ) {
2020-07-05 17:09:03 -04:00
if ( $version ) {
2019-09-02 20:41:05 -04:00
/* translators: %s: Version number. */
2016-08-23 19:48:28 -04:00
$version = sprintf ( __ ( '(This message was added in version %s.)' ), $version );
}
2019-10-31 20:41:01 -04:00
2017-11-30 18:11:00 -05:00
$message .= ' ' . sprintf (
2019-09-02 20:41:05 -04:00
/* translators: %s: Documentation URL. */
2017-11-30 18:11:00 -05:00
__ ( 'Please see <a href="%s">Debugging in WordPress</a> for more information.' ),
2023-02-23 05:38:21 -05:00
__ ( 'https://wordpress.org/documentation/article/debugging-in-wordpress/' )
2015-11-18 12:41:27 -05:00
);
2019-10-31 20:41:01 -04:00
trigger_error (
sprintf (
2020-07-07 05:56:02 -04:00
/* translators: Developer debugging message. 1: PHP function name, 2: Explanatory message, 3: WordPress version number. */
General: Clarify the deprecation messages in the `_deprecated_*()` functions family.
This makes the strings easier to translate and provides more details about what exactly is deprecated: a PHP function, a file name, or a WordPress hook.
The changes apply to:
* `_deprecated_function()`
* `_deprecated_constructor()`
* `_deprecated_file()`
* `_deprecated_argument()`
* `_deprecated_hook()`
* `_doing_it_wrong()`
Follow-up to [6514], [7884], [12536], [12584], [16939], [16942], [16945], [24439], [24723], [32989], [37861], [39315].
Props mukesh27, audrasjb, SergeyBiryukov.
Fixes #54658.
Built from https://develop.svn.wordpress.org/trunk@52609
git-svn-id: http://core.svn.wordpress.org/trunk@52197 1a063a9b-81f0-0310-95a4-ce76da25c4cd
2022-01-20 08:13:01 -05:00
__ ( 'Function %1$s was called <strong>incorrectly</strong>. %2$s %3$s' ),
Code Modernization: Rename parameters that use reserved keywords in `wp-includes/functions.php`.
While using reserved PHP keywords as parameter name labels is allowed, in the context of function calls using named parameters in PHP 8.0+, this will easily lead to confusion. To avoid that, it is recommended not to use reserved keywords as function parameter names.
This commit:
* Renames the `$echo` parameter to `$display` in:
* `wp_nonce_field()`
* `wp_referer_field()`
* `wp_original_referer_field()`
* Renames the `$string` parameter to `$input_string` in
* `_wp_json_convert_string()`
* `_wp_to_kebab_case()`
* Renames the `$list` parameter to `$input_list` in:
* `wp_parse_list()`
* `wp_parse_id_list()`
* `wp_parse_slug_list()`
* `wp_filter_object_list()`
* `wp_list_filter()`
* `wp_list_pluck()`
* `wp_list_sort()`
* Renames the `$array` parameter to `$input_array` in:
* `add_magic_quotes()`
* `wp_array_slice_assoc()`
* `_wp_array_get()`
* `_wp_array_set()`
* Renames the `$function` parameter to `$function_name` in:
* `_deprecated_function()`
* `_deprecated_argument()`
* `_doing_it_wrong()`
* Renames the `$class` parameter to `$class_name` in `_deprecated_constructor()`.
* Renames the `$default` parameter to `$default_value` in `apache_mod_loaded()`.
* Renames the `$var` parameter to `$value` in `wp_validate_boolean()`.
* Amends the `$input` parameter in `wp_parse_str()` for consistency.
Follow-up to [52946], [52996], [52997], [52998], [53003], [53014], [53029], [53039], [53116], [53117], [53137], [53174], [53184], [53185], [53192], [53193], [53198], [53203], [53207], [53215], [53216], [53220], [53230], [53232], [53236], [53239], [53240], [53242], [53243], [53245], [53246], [53257], [53269], [53270], [53271], [53272], [53273], [53274], [53275], [53276], [53277], [53281], [53283], [53284], [53285], [53287], [53364], [53365], [54927].
Props jrf, aristath, poena, justinahinon, SergeyBiryukov.
See #56788.
Built from https://develop.svn.wordpress.org/trunk@54929
git-svn-id: http://core.svn.wordpress.org/trunk@54481 1a063a9b-81f0-0310-95a4-ce76da25c4cd
2022-12-03 10:07:14 -05:00
$function_name ,
2019-10-31 20:41:01 -04:00
$message ,
$version
),
E_USER_NOTICE
);
2013-06-19 04:11:59 -04:00
} else {
2020-07-05 17:09:03 -04:00
if ( $version ) {
2016-08-23 19:48:28 -04:00
$version = sprintf ( '(This message was added in version %s.)' , $version );
}
2019-10-31 20:41:01 -04:00
2017-11-30 18:11:00 -05:00
$message .= sprintf (
' Please see <a href="%s">Debugging in WordPress</a> for more information.' ,
2023-02-23 05:38:21 -05:00
'https://wordpress.org/documentation/article/debugging-in-wordpress/'
2015-11-18 12:41:27 -05:00
);
2019-10-31 20:41:01 -04:00
trigger_error (
sprintf (
General: Clarify the deprecation messages in the `_deprecated_*()` functions family.
This makes the strings easier to translate and provides more details about what exactly is deprecated: a PHP function, a file name, or a WordPress hook.
The changes apply to:
* `_deprecated_function()`
* `_deprecated_constructor()`
* `_deprecated_file()`
* `_deprecated_argument()`
* `_deprecated_hook()`
* `_doing_it_wrong()`
Follow-up to [6514], [7884], [12536], [12584], [16939], [16942], [16945], [24439], [24723], [32989], [37861], [39315].
Props mukesh27, audrasjb, SergeyBiryukov.
Fixes #54658.
Built from https://develop.svn.wordpress.org/trunk@52609
git-svn-id: http://core.svn.wordpress.org/trunk@52197 1a063a9b-81f0-0310-95a4-ce76da25c4cd
2022-01-20 08:13:01 -05:00
'Function %1$s was called <strong>incorrectly</strong>. %2$s %3$s' ,
Code Modernization: Rename parameters that use reserved keywords in `wp-includes/functions.php`.
While using reserved PHP keywords as parameter name labels is allowed, in the context of function calls using named parameters in PHP 8.0+, this will easily lead to confusion. To avoid that, it is recommended not to use reserved keywords as function parameter names.
This commit:
* Renames the `$echo` parameter to `$display` in:
* `wp_nonce_field()`
* `wp_referer_field()`
* `wp_original_referer_field()`
* Renames the `$string` parameter to `$input_string` in
* `_wp_json_convert_string()`
* `_wp_to_kebab_case()`
* Renames the `$list` parameter to `$input_list` in:
* `wp_parse_list()`
* `wp_parse_id_list()`
* `wp_parse_slug_list()`
* `wp_filter_object_list()`
* `wp_list_filter()`
* `wp_list_pluck()`
* `wp_list_sort()`
* Renames the `$array` parameter to `$input_array` in:
* `add_magic_quotes()`
* `wp_array_slice_assoc()`
* `_wp_array_get()`
* `_wp_array_set()`
* Renames the `$function` parameter to `$function_name` in:
* `_deprecated_function()`
* `_deprecated_argument()`
* `_doing_it_wrong()`
* Renames the `$class` parameter to `$class_name` in `_deprecated_constructor()`.
* Renames the `$default` parameter to `$default_value` in `apache_mod_loaded()`.
* Renames the `$var` parameter to `$value` in `wp_validate_boolean()`.
* Amends the `$input` parameter in `wp_parse_str()` for consistency.
Follow-up to [52946], [52996], [52997], [52998], [53003], [53014], [53029], [53039], [53116], [53117], [53137], [53174], [53184], [53185], [53192], [53193], [53198], [53203], [53207], [53215], [53216], [53220], [53230], [53232], [53236], [53239], [53240], [53242], [53243], [53245], [53246], [53257], [53269], [53270], [53271], [53272], [53273], [53274], [53275], [53276], [53277], [53281], [53283], [53284], [53285], [53287], [53364], [53365], [54927].
Props jrf, aristath, poena, justinahinon, SergeyBiryukov.
See #56788.
Built from https://develop.svn.wordpress.org/trunk@54929
git-svn-id: http://core.svn.wordpress.org/trunk@54481 1a063a9b-81f0-0310-95a4-ce76da25c4cd
2022-12-03 10:07:14 -05:00
$function_name ,
2019-10-31 20:41:01 -04:00
$message ,
$version
),
E_USER_NOTICE
);
2013-06-19 04:11:59 -04:00
}
2010-12-15 07:06:39 -05:00
}
}
2008-03-19 20:33:59 -04:00
/**
2022-08-12 05:53:11 -04:00
* Determines whether the server is running an earlier than 1.5 . 0 version of lighttpd .
2008-06-15 05:38:32 -04:00
*
2008-08-10 12:45:50 -04:00
* @ since 2.5 . 0
2008-03-19 20:33:59 -04:00
*
2014-07-07 02:19:14 -04:00
* @ return bool Whether the server is running lighttpd < 1.5 . 0.
2008-03-19 20:33:59 -04:00
*/
function is_lighttpd_before_150 () {
2017-11-30 18:11:00 -05:00
$server_parts = explode ( '/' , isset ( $_SERVER [ 'SERVER_SOFTWARE' ] ) ? $_SERVER [ 'SERVER_SOFTWARE' ] : '' );
$server_parts [ 1 ] = isset ( $server_parts [ 1 ] ) ? $server_parts [ 1 ] : '' ;
2020-05-16 14:42:12 -04:00
return ( 'lighttpd' === $server_parts [ 0 ] && - 1 == version_compare ( $server_parts [ 1 ], '1.5.0' ) );
2008-03-19 20:33:59 -04:00
}
2008-03-21 00:10:01 -04:00
/**
2022-08-12 05:53:11 -04:00
* Determines whether the specified module exist in the Apache config .
2008-06-15 05:38:32 -04:00
*
2008-08-10 12:45:50 -04:00
* @ since 2.5 . 0
2008-03-21 00:10:01 -04:00
*
2015-05-25 12:11:25 -04:00
* @ global bool $is_apache
*
Code Modernization: Rename parameters that use reserved keywords in `wp-includes/functions.php`.
While using reserved PHP keywords as parameter name labels is allowed, in the context of function calls using named parameters in PHP 8.0+, this will easily lead to confusion. To avoid that, it is recommended not to use reserved keywords as function parameter names.
This commit:
* Renames the `$echo` parameter to `$display` in:
* `wp_nonce_field()`
* `wp_referer_field()`
* `wp_original_referer_field()`
* Renames the `$string` parameter to `$input_string` in
* `_wp_json_convert_string()`
* `_wp_to_kebab_case()`
* Renames the `$list` parameter to `$input_list` in:
* `wp_parse_list()`
* `wp_parse_id_list()`
* `wp_parse_slug_list()`
* `wp_filter_object_list()`
* `wp_list_filter()`
* `wp_list_pluck()`
* `wp_list_sort()`
* Renames the `$array` parameter to `$input_array` in:
* `add_magic_quotes()`
* `wp_array_slice_assoc()`
* `_wp_array_get()`
* `_wp_array_set()`
* Renames the `$function` parameter to `$function_name` in:
* `_deprecated_function()`
* `_deprecated_argument()`
* `_doing_it_wrong()`
* Renames the `$class` parameter to `$class_name` in `_deprecated_constructor()`.
* Renames the `$default` parameter to `$default_value` in `apache_mod_loaded()`.
* Renames the `$var` parameter to `$value` in `wp_validate_boolean()`.
* Amends the `$input` parameter in `wp_parse_str()` for consistency.
Follow-up to [52946], [52996], [52997], [52998], [53003], [53014], [53029], [53039], [53116], [53117], [53137], [53174], [53184], [53185], [53192], [53193], [53198], [53203], [53207], [53215], [53216], [53220], [53230], [53232], [53236], [53239], [53240], [53242], [53243], [53245], [53246], [53257], [53269], [53270], [53271], [53272], [53273], [53274], [53275], [53276], [53277], [53281], [53283], [53284], [53285], [53287], [53364], [53365], [54927].
Props jrf, aristath, poena, justinahinon, SergeyBiryukov.
See #56788.
Built from https://develop.svn.wordpress.org/trunk@54929
git-svn-id: http://core.svn.wordpress.org/trunk@54481 1a063a9b-81f0-0310-95a4-ce76da25c4cd
2022-12-03 10:07:14 -05:00
* @ param string $mod The module , e . g . mod_rewrite .
* @ param bool $default_value Optional . The default return value if the module is not found . Default false .
2014-07-07 02:19:14 -04:00
* @ return bool Whether the specified module is loaded .
2008-03-21 00:10:01 -04:00
*/
Code Modernization: Rename parameters that use reserved keywords in `wp-includes/functions.php`.
While using reserved PHP keywords as parameter name labels is allowed, in the context of function calls using named parameters in PHP 8.0+, this will easily lead to confusion. To avoid that, it is recommended not to use reserved keywords as function parameter names.
This commit:
* Renames the `$echo` parameter to `$display` in:
* `wp_nonce_field()`
* `wp_referer_field()`
* `wp_original_referer_field()`
* Renames the `$string` parameter to `$input_string` in
* `_wp_json_convert_string()`
* `_wp_to_kebab_case()`
* Renames the `$list` parameter to `$input_list` in:
* `wp_parse_list()`
* `wp_parse_id_list()`
* `wp_parse_slug_list()`
* `wp_filter_object_list()`
* `wp_list_filter()`
* `wp_list_pluck()`
* `wp_list_sort()`
* Renames the `$array` parameter to `$input_array` in:
* `add_magic_quotes()`
* `wp_array_slice_assoc()`
* `_wp_array_get()`
* `_wp_array_set()`
* Renames the `$function` parameter to `$function_name` in:
* `_deprecated_function()`
* `_deprecated_argument()`
* `_doing_it_wrong()`
* Renames the `$class` parameter to `$class_name` in `_deprecated_constructor()`.
* Renames the `$default` parameter to `$default_value` in `apache_mod_loaded()`.
* Renames the `$var` parameter to `$value` in `wp_validate_boolean()`.
* Amends the `$input` parameter in `wp_parse_str()` for consistency.
Follow-up to [52946], [52996], [52997], [52998], [53003], [53014], [53029], [53039], [53116], [53117], [53137], [53174], [53184], [53185], [53192], [53193], [53198], [53203], [53207], [53215], [53216], [53220], [53230], [53232], [53236], [53239], [53240], [53242], [53243], [53245], [53246], [53257], [53269], [53270], [53271], [53272], [53273], [53274], [53275], [53276], [53277], [53281], [53283], [53284], [53285], [53287], [53364], [53365], [54927].
Props jrf, aristath, poena, justinahinon, SergeyBiryukov.
See #56788.
Built from https://develop.svn.wordpress.org/trunk@54929
git-svn-id: http://core.svn.wordpress.org/trunk@54481 1a063a9b-81f0-0310-95a4-ce76da25c4cd
2022-12-03 10:07:14 -05:00
function apache_mod_loaded ( $mod , $default_value = false ) {
2008-03-21 00:10:01 -04:00
global $is_apache ;
2017-11-30 18:11:00 -05:00
if ( ! $is_apache ) {
2008-03-21 00:10:01 -04:00
return false ;
2017-11-30 18:11:00 -05:00
}
2008-03-21 00:10:01 -04:00
2022-09-24 09:53:13 -04:00
$loaded_mods = array ();
2014-07-30 13:28:17 -04:00
if ( function_exists ( 'apache_get_modules' ) ) {
2022-09-24 09:53:13 -04:00
$loaded_mods = apache_get_modules ();
if ( in_array ( $mod , $loaded_mods , true ) ) {
2008-03-21 00:10:01 -04:00
return true ;
2017-11-30 18:11:00 -05:00
}
2022-09-24 09:53:13 -04:00
}
if ( empty ( $loaded_mods )
&& function_exists ( 'phpinfo' )
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 10:36:26 -04:00
&& ! str_contains ( ini_get ( 'disable_functions' ), 'phpinfo' )
2022-09-24 09:53:13 -04:00
) {
ob_start ();
phpinfo ( INFO_MODULES );
$phpinfo = ob_get_clean ();
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 10:36:26 -04:00
if ( str_contains ( $phpinfo , $mod ) ) {
2017-11-30 18:11:00 -05:00
return true ;
}
2008-03-21 00:10:01 -04:00
}
2020-05-16 14:42:12 -04:00
Code Modernization: Rename parameters that use reserved keywords in `wp-includes/functions.php`.
While using reserved PHP keywords as parameter name labels is allowed, in the context of function calls using named parameters in PHP 8.0+, this will easily lead to confusion. To avoid that, it is recommended not to use reserved keywords as function parameter names.
This commit:
* Renames the `$echo` parameter to `$display` in:
* `wp_nonce_field()`
* `wp_referer_field()`
* `wp_original_referer_field()`
* Renames the `$string` parameter to `$input_string` in
* `_wp_json_convert_string()`
* `_wp_to_kebab_case()`
* Renames the `$list` parameter to `$input_list` in:
* `wp_parse_list()`
* `wp_parse_id_list()`
* `wp_parse_slug_list()`
* `wp_filter_object_list()`
* `wp_list_filter()`
* `wp_list_pluck()`
* `wp_list_sort()`
* Renames the `$array` parameter to `$input_array` in:
* `add_magic_quotes()`
* `wp_array_slice_assoc()`
* `_wp_array_get()`
* `_wp_array_set()`
* Renames the `$function` parameter to `$function_name` in:
* `_deprecated_function()`
* `_deprecated_argument()`
* `_doing_it_wrong()`
* Renames the `$class` parameter to `$class_name` in `_deprecated_constructor()`.
* Renames the `$default` parameter to `$default_value` in `apache_mod_loaded()`.
* Renames the `$var` parameter to `$value` in `wp_validate_boolean()`.
* Amends the `$input` parameter in `wp_parse_str()` for consistency.
Follow-up to [52946], [52996], [52997], [52998], [53003], [53014], [53029], [53039], [53116], [53117], [53137], [53174], [53184], [53185], [53192], [53193], [53198], [53203], [53207], [53215], [53216], [53220], [53230], [53232], [53236], [53239], [53240], [53242], [53243], [53245], [53246], [53257], [53269], [53270], [53271], [53272], [53273], [53274], [53275], [53276], [53277], [53281], [53283], [53284], [53285], [53287], [53364], [53365], [54927].
Props jrf, aristath, poena, justinahinon, SergeyBiryukov.
See #56788.
Built from https://develop.svn.wordpress.org/trunk@54929
git-svn-id: http://core.svn.wordpress.org/trunk@54481 1a063a9b-81f0-0310-95a4-ce76da25c4cd
2022-12-03 10:07:14 -05:00
return $default_value ;
2008-03-21 00:10:01 -04:00
}
2010-12-14 03:31:33 -05:00
/**
2022-08-12 05:53:11 -04:00
* Checks if IIS 7 + supports pretty permalinks .
2010-12-14 03:31:33 -05:00
*
* @ since 2.8 . 0
*
2015-05-25 12:11:25 -04:00
* @ global bool $is_iis7
*
2014-07-07 02:19:14 -04:00
* @ return bool Whether IIS7 supports permalinks .
2010-12-14 03:31:33 -05:00
*/
function iis7_supports_permalinks () {
global $is_iis7 ;
$supports_permalinks = false ;
if ( $is_iis7 ) {
2013-07-08 16:27:06 -04:00
/* First we check if the DOMDocument class exists . If it does not exist , then we cannot
* easily update the xml configuration file , hence we just bail out and tell user that
* pretty permalinks cannot be used .
*
2010-12-14 03:31:33 -05:00
* Next we check if the URL Rewrite Module 1.1 is loaded and enabled for the web site . When
* URL Rewrite 1.1 is loaded it always sets a server variable called 'IIS_UrlRewriteModule' .
* Lastly we make sure that PHP is running via FastCGI . This is important because if it runs
* via ISAPI then pretty permalinks will not work .
*/
2020-05-16 14:42:12 -04:00
$supports_permalinks = class_exists ( 'DOMDocument' , false ) && isset ( $_SERVER [ 'IIS_UrlRewriteModule' ] ) && ( 'cgi-fcgi' === PHP_SAPI );
2010-12-14 03:31:33 -05:00
}
2014-04-13 20:20:14 -04:00
/**
2016-05-22 14:36:27 -04:00
* Filters whether IIS 7 + supports pretty permalinks .
2014-04-13 20:20:14 -04:00
*
* @ since 2.8 . 0
*
* @ param bool $supports_permalinks Whether IIS7 supports permalinks . Default false .
*/
return apply_filters ( 'iis7_supports_permalinks' , $supports_permalinks );
2010-12-14 03:31:33 -05:00
}
2008-06-15 05:38:32 -04:00
/**
2017-10-24 18:50:49 -04:00
* Validates a file name and path against an allowed set of rules .
2008-06-15 05:38:32 -04:00
*
2017-10-24 18:50:49 -04:00
* A return value of `1` means the file path contains directory traversal .
*
* A return value of `2` means the file path contains a Windows drive path .
*
* A return value of `3` means the file is not in the allowed files list .
2008-06-15 05:38:32 -04:00
*
2008-08-10 12:45:50 -04:00
* @ since 1.2 . 0
2008-06-15 05:38:32 -04:00
*
2019-10-26 17:09:04 -04:00
* @ param string $file File path .
2023-02-21 11:39:19 -05:00
* @ param string [] $allowed_files Optional . Array of allowed files . Default empty array .
2008-06-15 05:38:32 -04:00
* @ return int 0 means nothing is wrong , greater than 0 means something was wrong .
*/
2017-10-24 19:15:49 -04:00
function validate_file ( $file , $allowed_files = array () ) {
2021-08-16 18:53:02 -04:00
if ( ! is_scalar ( $file ) || '' === $file ) {
return 0 ;
}
2017-10-24 19:15:49 -04:00
// `../` on its own is not allowed:
if ( '../' === $file ) {
2008-05-12 19:51:54 -04:00
return 1 ;
2017-10-24 19:15:49 -04:00
}
2008-05-12 19:51:54 -04:00
2021-12-25 06:17:04 -05:00
// More than one occurrence of `../` is not allowed:
2017-10-24 19:15:49 -04:00
if ( preg_match_all ( '#\.\./#' , $file , $matches , PREG_SET_ORDER ) && ( count ( $matches ) > 1 ) ) {
2008-05-12 19:51:54 -04:00
return 1 ;
2017-10-24 19:15:49 -04:00
}
// `../` which does not occur at the end of the path is not allowed:
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 10:36:26 -04:00
if ( str_contains ( $file , '../' ) && '../' !== mb_substr ( $file , - 3 , 3 ) ) {
2017-10-24 19:15:49 -04:00
return 1 ;
}
2008-05-12 19:51:54 -04:00
2017-10-24 19:15:49 -04:00
// Files not in the allowed file list are not allowed:
2020-04-04 23:02:11 -04:00
if ( ! empty ( $allowed_files ) && ! in_array ( $file , $allowed_files , true ) ) {
2008-05-12 19:51:54 -04:00
return 3 ;
2017-11-30 18:11:00 -05:00
}
2008-05-12 19:51:54 -04:00
2017-10-24 19:15:49 -04:00
// Absolute Windows drive paths are not allowed:
2020-05-16 14:42:12 -04:00
if ( ':' === substr ( $file , 1 , 1 ) ) {
2009-12-01 17:03:13 -05:00
return 2 ;
2017-11-30 18:11:00 -05:00
}
2009-12-01 17:03:13 -05:00
2008-05-12 19:51:54 -04:00
return 0 ;
}
2008-06-15 05:38:32 -04:00
/**
2022-08-12 05:53:11 -04:00
* Determines whether to force SSL used for the Administration Screens .
2008-06-15 05:38:32 -04:00
*
2008-08-10 12:45:50 -04:00
* @ since 2.6 . 0
2008-06-15 05:38:32 -04:00
*
2014-07-07 02:19:14 -04:00
* @ param string | bool $force Optional . Whether to force SSL in admin screens . Default null .
2008-06-15 05:38:32 -04:00
* @ return bool True if forced , false if not forced .
*/
2009-09-08 10:46:06 -04:00
function force_ssl_admin ( $force = null ) {
static $forced = false ;
2008-06-11 13:25:55 -04:00
2017-11-30 18:11:00 -05:00
if ( ! is_null ( $force ) ) {
2008-06-14 16:58:43 -04:00
$old_forced = $forced ;
2017-11-30 18:11:00 -05:00
$forced = $force ;
2008-06-11 13:25:55 -04:00
return $old_forced ;
}
return $forced ;
}
2008-06-29 23:23:44 -04:00
/**
2022-08-12 05:53:11 -04:00
* Guesses the URL for the site .
2008-06-29 23:23:44 -04:00
*
* Will remove wp - admin links to retrieve only return URLs not in the wp - admin
* directory .
*
2008-08-10 12:45:50 -04:00
* @ since 2.6 . 0
2008-06-29 23:23:44 -04:00
*
2014-07-07 02:19:14 -04:00
* @ return string The guessed URL .
2008-06-29 23:23:44 -04:00
*/
2008-06-24 13:36:21 -04:00
function wp_guess_url () {
2020-05-16 14:42:12 -04:00
if ( defined ( 'WP_SITEURL' ) && '' !== WP_SITEURL ) {
2008-06-24 13:36:21 -04:00
$url = WP_SITEURL ;
2012-09-10 15:37:08 -04:00
} else {
2017-11-30 18:11:00 -05:00
$abspath_fix = str_replace ( '\\' , '/' , ABSPATH );
2013-09-13 23:43:10 -04:00
$script_filename_dir = dirname ( $_SERVER [ 'SCRIPT_FILENAME' ] );
2020-01-28 19:45:18 -05:00
// The request is for the admin.
2023-06-26 06:17:25 -04:00
if ( str_contains ( $_SERVER [ 'REQUEST_URI' ], 'wp-admin' ) || str_contains ( $_SERVER [ 'REQUEST_URI' ], 'wp-login.php' ) ) {
General: Correct path replacement regex in `wp_guess_url`.
In `wp_guess_url`, the regex to check for wp-login.php in the URL is slightly too permissive, not escaping `.` in "wp-login.php". `.` is a token in regex that matches any character.
This change simply escapes the `.` and adds unit test coverage for `wp_guess_url`.
Props cfinke, ocean90, jrf, voldemortensen, jdgrimes, curdin, netweb, petitphp, SergeyBiryukov, costdev.
Fixes #36827.
Built from https://develop.svn.wordpress.org/trunk@54146
git-svn-id: http://core.svn.wordpress.org/trunk@53705 1a063a9b-81f0-0310-95a4-ce76da25c4cd
2022-09-13 15:50:12 -04:00
$path = preg_replace ( '#/(wp-admin/?.*|wp-login\.php.*)#i' , '' , $_SERVER [ 'REQUEST_URI' ] );
2013-09-12 02:57:09 -04:00
2020-01-28 19:45:18 -05:00
// The request is for a file in ABSPATH.
2020-05-16 14:42:12 -04:00
} elseif ( $script_filename_dir . '/' === $abspath_fix ) {
2020-01-28 19:45:18 -05:00
// Strip off any file/query params in the path.
2013-09-12 02:57:09 -04:00
$path = preg_replace ( '#/[^/]*$#i' , '' , $_SERVER [ 'PHP_SELF' ] );
} else {
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 10:36:26 -04:00
if ( str_contains ( $_SERVER [ 'SCRIPT_FILENAME' ], $abspath_fix ) ) {
2020-01-28 19:45:18 -05:00
// Request is hitting a file inside ABSPATH.
2013-09-13 23:43:10 -04:00
$directory = str_replace ( ABSPATH , '' , $script_filename_dir );
2020-01-28 19:45:18 -05:00
// Strip off the subdirectory, and any file/query params.
2017-11-30 18:11:00 -05:00
$path = preg_replace ( '#/' . preg_quote ( $directory , '#' ) . '/[^/]*$#i' , '' , $_SERVER [ 'REQUEST_URI' ] );
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 10:36:26 -04:00
} elseif ( str_contains ( $abspath_fix , $script_filename_dir ) ) {
2020-01-28 19:45:18 -05:00
// Request is hitting a file above ABSPATH.
2013-11-06 22:34:10 -05:00
$subdirectory = substr ( $abspath_fix , strpos ( $abspath_fix , $script_filename_dir ) + strlen ( $script_filename_dir ) );
2020-01-28 19:45:18 -05:00
// Strip off any file/query params from the path, appending the subdirectory to the installation.
2017-11-30 18:11:00 -05:00
$path = preg_replace ( '#/[^/]*$#i' , '' , $_SERVER [ 'REQUEST_URI' ] ) . $subdirectory ;
2013-09-13 23:43:10 -04:00
} else {
$path = $_SERVER [ 'REQUEST_URI' ];
2013-09-12 02:57:09 -04:00
}
}
2020-01-28 19:45:18 -05:00
$schema = is_ssl () ? 'https://' : 'http://' ; // set_url_scheme() is not defined yet.
2017-11-30 18:11:00 -05:00
$url = $schema . $_SERVER [ 'HTTP_HOST' ] . $path ;
2012-09-10 15:37:08 -04:00
}
2012-08-30 09:33:00 -04:00
2017-11-30 18:11:00 -05:00
return rtrim ( $url , '/' );
2008-06-24 13:36:21 -04:00
}
2011-09-15 16:23:00 -04:00
/**
2022-08-12 05:53:11 -04:00
* Temporarily suspends cache additions .
2011-09-15 16:23:00 -04:00
*
* Stops more data being added to the cache , but still allows cache retrieval .
* This is useful for actions , such as imports , when a lot of data would otherwise
* be almost uselessly added to the cache .
*
* Suspension lasts for a single page load at most . Remember to call this
* function again if you wish to re - enable cache adds earlier .
*
* @ since 3.3 . 0
*
* @ param bool $suspend Optional . Suspends additions if true , re - enables them if false .
2023-02-21 11:39:19 -05:00
* Defaults to not changing the current setting .
* @ return bool The current suspend setting .
2011-09-15 16:23:00 -04:00
*/
function wp_suspend_cache_addition ( $suspend = null ) {
static $_suspend = false ;
2017-11-30 18:11:00 -05:00
if ( is_bool ( $suspend ) ) {
2011-09-15 16:23:00 -04:00
$_suspend = $suspend ;
2017-11-30 18:11:00 -05:00
}
2011-09-15 16:23:00 -04:00
return $_suspend ;
}
2008-10-08 20:50:52 -04:00
/**
2022-08-12 05:53:11 -04:00
* Suspends cache invalidation .
2008-10-08 20:50:52 -04:00
*
2017-07-12 17:26:44 -04:00
* Turns cache invalidation on and off . Useful during imports where you don ' t want to do
2014-07-07 02:19:14 -04:00
* invalidations every time a post is inserted . Callers must be sure that what they are
* doing won ' t lead to an inconsistent cache when invalidation is suspended .
2008-10-08 20:50:52 -04:00
*
* @ since 2.7 . 0
*
2015-05-25 12:11:25 -04:00
* @ global bool $_wp_suspend_cache_invalidation
*
2014-07-07 02:19:14 -04:00
* @ param bool $suspend Optional . Whether to suspend or enable cache invalidation . Default true .
* @ return bool The current suspend setting .
2008-10-08 20:50:52 -04:00
*/
2014-07-07 02:19:14 -04:00
function wp_suspend_cache_invalidation ( $suspend = true ) {
2008-10-08 20:50:52 -04:00
global $_wp_suspend_cache_invalidation ;
2017-11-30 18:11:00 -05:00
$current_suspend = $_wp_suspend_cache_invalidation ;
2008-10-08 20:50:52 -04:00
$_wp_suspend_cache_invalidation = $suspend ;
return $current_suspend ;
}
2010-01-12 16:52:51 -05:00
/**
2022-08-12 05:53:11 -04:00
* Determines whether a site is the main site of the current network .
2010-01-12 16:52:51 -05:00
*
* @ since 3.0 . 0
2018-02-09 11:55:31 -05:00
* @ since 4.9 . 0 The `$network_id` parameter was added .
2010-01-12 16:52:51 -05:00
*
2017-09-15 07:15:52 -04:00
* @ param int $site_id Optional . Site ID to test . Defaults to current site .
* @ param int $network_id Optional . Network ID of the network to check for .
* Defaults to current network .
2014-07-07 02:19:14 -04:00
* @ return bool True if $site_id is the main site of the network , or if not
* running Multisite .
2010-01-12 16:52:51 -05:00
*/
2017-09-15 07:15:52 -04:00
function is_main_site ( $site_id = null , $network_id = null ) {
if ( ! is_multisite () ) {
2010-01-12 16:52:51 -05:00
return true ;
2017-09-15 07:15:52 -04:00
}
2010-01-12 16:52:51 -05:00
2017-09-15 07:15:52 -04:00
if ( ! $site_id ) {
2013-08-27 23:35:08 -04:00
$site_id = get_current_blog_id ();
2017-09-15 07:15:52 -04:00
}
$site_id = ( int ) $site_id ;
2020-02-09 11:55:09 -05:00
return get_main_site_id ( $network_id ) === $site_id ;
2017-09-15 07:15:52 -04:00
}
/**
* Gets the main site ID .
*
* @ since 4.9 . 0
*
* @ param int $network_id Optional . The ID of the network for which to get the main site .
* Defaults to the current network .
* @ return int The ID of the main site .
*/
function get_main_site_id ( $network_id = null ) {
if ( ! is_multisite () ) {
2017-10-14 18:46:48 -04:00
return get_current_blog_id ();
2017-09-15 07:15:52 -04:00
}
$network = get_network ( $network_id );
if ( ! $network ) {
return 0 ;
}
2017-10-14 18:42:54 -04:00
return $network -> site_id ;
2013-08-27 23:35:08 -04:00
}
/**
2022-08-12 05:53:11 -04:00
* Determines whether a network is the main network of the Multisite installation .
2013-08-27 23:35:08 -04:00
*
* @ since 3.7 . 0
*
* @ param int $network_id Optional . Network ID to test . Defaults to current network .
2014-07-07 02:19:14 -04:00
* @ return bool True if $network_id is the main network , or if not running Multisite .
2013-08-27 23:35:08 -04:00
*/
function is_main_network ( $network_id = null ) {
2015-06-14 17:45:25 -04:00
if ( ! is_multisite () ) {
2013-08-27 23:35:08 -04:00
return true ;
2015-06-14 17:45:25 -04:00
}
2013-08-27 23:35:08 -04:00
2015-06-14 17:45:25 -04:00
if ( null === $network_id ) {
2016-10-19 00:47:30 -04:00
$network_id = get_current_network_id ();
2015-06-14 17:45:25 -04:00
}
2013-08-27 23:35:08 -04:00
$network_id = ( int ) $network_id ;
2020-02-09 11:55:09 -05:00
return ( get_main_network_id () === $network_id );
2015-06-14 17:45:25 -04:00
}
2013-08-27 23:35:08 -04:00
2015-06-14 17:45:25 -04:00
/**
2022-08-12 05:53:11 -04:00
* Gets the main network ID .
2015-06-14 17:45:25 -04:00
*
* @ since 4.3 . 0
*
* @ return int The ID of the main network .
*/
function get_main_network_id () {
if ( ! is_multisite () ) {
return 1 ;
}
2013-08-27 23:35:08 -04:00
2016-10-19 00:47:30 -04:00
$current_network = get_network ();
2016-06-09 16:34:28 -04:00
2015-06-14 17:45:25 -04:00
if ( defined ( 'PRIMARY_NETWORK_ID' ) ) {
$main_network_id = PRIMARY_NETWORK_ID ;
2016-10-19 00:47:30 -04:00
} elseif ( isset ( $current_network -> id ) && 1 === ( int ) $current_network -> id ) {
2015-06-14 17:45:25 -04:00
// If the current network has an ID of 1, assume it is the main network.
$main_network_id = 1 ;
} else {
2017-11-30 18:11:00 -05:00
$_networks = get_networks (
array (
'fields' => 'ids' ,
'number' => 1 ,
)
);
2016-09-20 14:47:27 -04:00
$main_network_id = array_shift ( $_networks );
2015-06-14 17:45:25 -04:00
}
2010-01-12 16:52:51 -05:00
2015-06-14 17:45:25 -04:00
/**
2016-05-22 14:36:27 -04:00
* Filters the main network ID .
2015-06-14 17:45:25 -04:00
*
* @ since 4.3 . 0
*
* @ param int $main_network_id The ID of the main network .
*/
return ( int ) apply_filters ( 'get_main_network_id' , $main_network_id );
2010-01-12 16:52:51 -05:00
}
2018-03-15 22:15:31 -04:00
/**
* Determines whether site meta is enabled .
*
* This function checks whether the 'blogmeta' database table exists . The result is saved as
* a setting for the main network , making it essentially a global setting . Subsequent requests
* will refer to this setting instead of running the query .
*
2019-01-08 03:18:50 -05:00
* @ since 5.1 . 0
2018-03-15 22:15:31 -04:00
*
* @ global wpdb $wpdb WordPress database abstraction object .
*
* @ return bool True if site meta is supported , false otherwise .
*/
function is_site_meta_supported () {
global $wpdb ;
if ( ! is_multisite () ) {
return false ;
}
$network_id = get_main_network_id ();
$supported = get_network_option ( $network_id , 'site_meta_supported' , false );
if ( false === $supported ) {
$supported = $wpdb -> get_var ( " SHOW TABLES LIKE ' { $wpdb -> blogmeta } ' " ) ? 1 : 0 ;
update_network_option ( $network_id , 'site_meta_supported' , $supported );
}
return ( bool ) $supported ;
}
2009-03-09 20:50:00 -04:00
/**
2022-08-12 05:53:11 -04:00
* Modifies gmt_offset for smart timezone handling .
2009-03-17 22:43:45 -04:00
*
2011-07-21 13:48:25 -04:00
* Overrides the gmt_offset option if we have a timezone_string available .
2010-02-13 03:59:04 -05:00
*
2010-02-18 20:08:39 -05:00
* @ since 2.8 . 0
2010-02-13 03:59:04 -05:00
*
2015-05-25 12:11:25 -04:00
* @ return float | false Timezone GMT offset , false otherwise .
2009-03-09 20:50:00 -04:00
*/
function wp_timezone_override_offset () {
2019-07-02 19:42:58 -04:00
$timezone_string = get_option ( 'timezone_string' );
if ( ! $timezone_string ) {
2009-06-18 13:40:40 -04:00
return false ;
}
2009-03-17 22:43:45 -04:00
2009-06-18 13:40:40 -04:00
$timezone_object = timezone_open ( $timezone_string );
$datetime_object = date_create ();
if ( false === $timezone_object || false === $datetime_object ) {
return false ;
}
2012-09-25 01:26:19 -04:00
return round ( timezone_offset_get ( $timezone_object , $datetime_object ) / HOUR_IN_SECONDS , 2 );
2009-03-09 20:50:00 -04:00
}
2010-02-13 03:59:04 -05:00
/**
2013-08-23 09:57:08 -04:00
* Sort - helper for timezones .
2010-02-13 03:59:04 -05:00
*
2010-02-18 20:08:39 -05:00
* @ since 2.9 . 0
2014-07-07 02:19:14 -04:00
* @ access private
2010-02-13 03:59:04 -05:00
*
2013-08-23 09:57:08 -04:00
* @ param array $a
* @ param array $b
2010-02-18 20:08:39 -05:00
* @ return int
2010-02-13 03:59:04 -05:00
*/
2009-06-18 13:40:40 -04:00
function _wp_timezone_choice_usort_callback ( $a , $b ) {
2020-01-28 19:45:18 -05:00
// Don't use translated versions of Etc.
2009-06-18 13:40:40 -04:00
if ( 'Etc' === $a [ 'continent' ] && 'Etc' === $b [ 'continent' ] ) {
2020-01-28 19:45:18 -05:00
// Make the order of these more like the old dropdown.
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 10:57:24 -04:00
if ( str_starts_with ( $a [ 'city' ], 'GMT+' ) && str_starts_with ( $b [ 'city' ], 'GMT+' ) ) {
2009-06-18 13:40:40 -04:00
return - 1 * ( strnatcasecmp ( $a [ 'city' ], $b [ 'city' ] ) );
}
if ( 'UTC' === $a [ 'city' ] ) {
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 10:57:24 -04:00
if ( str_starts_with ( $b [ 'city' ], 'GMT+' ) ) {
2009-06-18 13:40:40 -04:00
return 1 ;
}
return - 1 ;
}
if ( 'UTC' === $b [ 'city' ] ) {
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 10:57:24 -04:00
if ( str_starts_with ( $a [ 'city' ], 'GMT+' ) ) {
2009-06-18 13:40:40 -04:00
return - 1 ;
}
return 1 ;
}
return strnatcasecmp ( $a [ 'city' ], $b [ 'city' ] );
}
if ( $a [ 't_continent' ] == $b [ 't_continent' ] ) {
if ( $a [ 't_city' ] == $b [ 't_city' ] ) {
return strnatcasecmp ( $a [ 't_subcity' ], $b [ 't_subcity' ] );
}
return strnatcasecmp ( $a [ 't_city' ], $b [ 't_city' ] );
} else {
2020-01-28 19:45:18 -05:00
// Force Etc to the bottom of the list.
2009-06-18 13:40:40 -04:00
if ( 'Etc' === $a [ 'continent' ] ) {
return 1 ;
}
if ( 'Etc' === $b [ 'continent' ] ) {
return - 1 ;
}
return strnatcasecmp ( $a [ 't_continent' ], $b [ 't_continent' ] );
}
2009-03-09 20:50:00 -04:00
}
/**
2014-07-07 02:19:14 -04:00
* Gives a nicely - formatted list of timezone strings .
2009-03-09 20:50:00 -04:00
*
2010-02-18 20:08:39 -05:00
* @ since 2.9 . 0
2016-11-01 05:16:31 -04:00
* @ since 4.7 . 0 Added the `$locale` parameter .
2009-03-09 20:50:00 -04:00
*
2014-07-07 02:19:14 -04:00
* @ param string $selected_zone Selected timezone .
2016-11-01 05:16:31 -04:00
* @ param string $locale Optional . Locale to load the timezones in . Default current site locale .
2010-02-13 03:59:04 -05:00
* @ return string
2009-03-09 20:50:00 -04:00
*/
2016-11-01 05:16:31 -04:00
function wp_timezone_choice ( $selected_zone , $locale = null ) {
static $mo_loaded = false , $locale_loaded = null ;
2009-05-14 14:58:37 -04:00
2017-11-30 18:11:00 -05:00
$continents = array ( 'Africa' , 'America' , 'Antarctica' , 'Arctic' , 'Asia' , 'Atlantic' , 'Australia' , 'Europe' , 'Indian' , 'Pacific' );
2009-03-10 11:26:52 -04:00
2016-11-01 05:16:31 -04:00
// Load translations for continents and cities.
if ( ! $mo_loaded || $locale !== $locale_loaded ) {
$locale_loaded = $locale ? $locale : get_locale ();
2017-11-30 18:11:00 -05:00
$mofile = WP_LANG_DIR . '/continents-cities-' . $locale_loaded . '.mo' ;
2016-11-01 05:16:31 -04:00
unload_textdomain ( 'continents-cities' );
2022-11-10 14:40:11 -05:00
load_textdomain ( 'continents-cities' , $mofile , $locale_loaded );
2009-05-14 14:58:37 -04:00
$mo_loaded = true ;
}
Date/Time: Correct timezone dropdown list creation in `wp_timezone_choice()`.
This fixes a bug where if the `timezone_string` is set to a timezone name which has since been deprecated, no option would be (pre-)selected in the generated dropdown list and when the form using the dropdown list is submitted, the “old”, originally saved value would be lost as the form would submit without a value being selected for the `timezone_string` field.
The fix is a little hacky: it basically checks ahead of generating the actual dropdown list whether the `$selected_zone` value would be recognized and set to “selected” and if not, verifies that the value ''is'' a valid but outdated timezone name and if so, adds an extra dropdown entry to the top of the list with the original value and sets this value to “selected”.
See the extensive write-up about this in ticket #56468.
Also see: [https://www.php.net/manual/en/datetimezone.listidentifiers.php PHP Manual: timezone_identifiers_list()].
Note: There are no pre-existing tests at all for this method and adding a complete set of tests for this method is outside the scope of this ticket, so this fix does not contain any tests.
Follow-up to [54207], [54217], [54227], [54229], [54230], [54232].
Props jrf, costdev, marcyoast.
See #56468.
Built from https://develop.svn.wordpress.org/trunk@54233
git-svn-id: http://core.svn.wordpress.org/trunk@53792 1a063a9b-81f0-0310-95a4-ce76da25c4cd
2022-09-19 21:02:10 -04:00
$tz_identifiers = timezone_identifiers_list ();
$zonen = array ();
foreach ( $tz_identifiers as $zone ) {
2009-06-18 13:40:40 -04:00
$zone = explode ( '/' , $zone );
2020-04-04 23:02:11 -04:00
if ( ! in_array ( $zone [ 0 ], $continents , true ) ) {
2009-03-10 11:26:52 -04:00
continue ;
2009-06-18 13:40:40 -04:00
}
2009-03-09 20:50:00 -04:00
2020-01-28 19:45:18 -05:00
// This determines what gets set and translated - we don't translate Etc/* strings here, they are done later.
2017-11-30 18:11:00 -05:00
$exists = array (
2010-03-19 17:15:00 -04:00
0 => ( isset ( $zone [ 0 ] ) && $zone [ 0 ] ),
1 => ( isset ( $zone [ 1 ] ) && $zone [ 1 ] ),
2 => ( isset ( $zone [ 2 ] ) && $zone [ 2 ] ),
2009-06-18 13:40:40 -04:00
);
2010-03-19 17:15:00 -04:00
$exists [ 3 ] = ( $exists [ 0 ] && 'Etc' !== $zone [ 0 ] );
$exists [ 4 ] = ( $exists [ 1 ] && $exists [ 3 ] );
$exists [ 5 ] = ( $exists [ 2 ] && $exists [ 3 ] );
2009-06-18 13:40:40 -04:00
2019-01-11 01:04:49 -05:00
// phpcs:disable WordPress.WP.I18n.LowLevelTranslationFunction,WordPress.WP.I18n.NonSingularStringLiteralText
2009-06-18 13:40:40 -04:00
$zonen [] = array (
'continent' => ( $exists [ 0 ] ? $zone [ 0 ] : '' ),
'city' => ( $exists [ 1 ] ? $zone [ 1 ] : '' ),
'subcity' => ( $exists [ 2 ] ? $zone [ 2 ] : '' ),
't_continent' => ( $exists [ 3 ] ? translate ( str_replace ( '_' , ' ' , $zone [ 0 ] ), 'continents-cities' ) : '' ),
't_city' => ( $exists [ 4 ] ? translate ( str_replace ( '_' , ' ' , $zone [ 1 ] ), 'continents-cities' ) : '' ),
2017-11-30 18:11:00 -05:00
't_subcity' => ( $exists [ 5 ] ? translate ( str_replace ( '_' , ' ' , $zone [ 2 ] ), 'continents-cities' ) : '' ),
2009-06-18 13:40:40 -04:00
);
2019-01-11 01:04:49 -05:00
// phpcs:enable
2009-06-18 13:40:40 -04:00
}
usort ( $zonen , '_wp_timezone_choice_usort_callback' );
$structure = array ();
if ( empty ( $selected_zone ) ) {
$structure [] = '<option selected="selected" value="">' . __ ( 'Select a city' ) . '</option>' ;
}
Date/Time: Correct timezone dropdown list creation in `wp_timezone_choice()`.
This fixes a bug where if the `timezone_string` is set to a timezone name which has since been deprecated, no option would be (pre-)selected in the generated dropdown list and when the form using the dropdown list is submitted, the “old”, originally saved value would be lost as the form would submit without a value being selected for the `timezone_string` field.
The fix is a little hacky: it basically checks ahead of generating the actual dropdown list whether the `$selected_zone` value would be recognized and set to “selected” and if not, verifies that the value ''is'' a valid but outdated timezone name and if so, adds an extra dropdown entry to the top of the list with the original value and sets this value to “selected”.
See the extensive write-up about this in ticket #56468.
Also see: [https://www.php.net/manual/en/datetimezone.listidentifiers.php PHP Manual: timezone_identifiers_list()].
Note: There are no pre-existing tests at all for this method and adding a complete set of tests for this method is outside the scope of this ticket, so this fix does not contain any tests.
Follow-up to [54207], [54217], [54227], [54229], [54230], [54232].
Props jrf, costdev, marcyoast.
See #56468.
Built from https://develop.svn.wordpress.org/trunk@54233
git-svn-id: http://core.svn.wordpress.org/trunk@53792 1a063a9b-81f0-0310-95a4-ce76da25c4cd
2022-09-19 21:02:10 -04:00
// If this is a deprecated, but valid, timezone string, display it at the top of the list as-is.
if ( in_array ( $selected_zone , $tz_identifiers , true ) === false
&& in_array ( $selected_zone , timezone_identifiers_list ( DateTimeZone :: ALL_WITH_BC ), true )
) {
$structure [] = '<option selected="selected" value="' . esc_attr ( $selected_zone ) . '">' . esc_html ( $selected_zone ) . '</option>' ;
}
2009-06-18 13:40:40 -04:00
foreach ( $zonen as $key => $zone ) {
2020-01-28 19:45:18 -05:00
// Build value in an array to join later.
2009-06-18 13:40:40 -04:00
$value = array ( $zone [ 'continent' ] );
if ( empty ( $zone [ 'city' ] ) ) {
2020-01-28 19:45:18 -05:00
// It's at the continent level (generally won't happen).
2009-06-18 13:40:40 -04:00
$display = $zone [ 't_continent' ];
2009-03-09 20:50:00 -04:00
} else {
2020-01-28 19:45:18 -05:00
// It's inside a continent group.
2009-09-14 10:03:32 -04:00
2020-01-28 19:45:18 -05:00
// Continent optgroup.
2017-11-30 18:11:00 -05:00
if ( ! isset ( $zonen [ $key - 1 ] ) || $zonen [ $key - 1 ][ 'continent' ] !== $zone [ 'continent' ] ) {
$label = $zone [ 't_continent' ];
$structure [] = '<optgroup label="' . esc_attr ( $label ) . '">' ;
2009-06-18 13:40:40 -04:00
}
2009-09-14 10:03:32 -04:00
2020-01-28 19:45:18 -05:00
// Add the city to the value.
2009-06-18 13:40:40 -04:00
$value [] = $zone [ 'city' ];
2009-12-23 09:16:36 -05:00
$display = $zone [ 't_city' ];
2017-11-30 18:11:00 -05:00
if ( ! empty ( $zone [ 'subcity' ] ) ) {
2020-01-28 19:45:18 -05:00
// Add the subcity to the value.
2017-11-30 18:11:00 -05:00
$value [] = $zone [ 'subcity' ];
2009-12-23 09:16:36 -05:00
$display .= ' - ' . $zone [ 't_subcity' ];
2009-06-18 13:40:40 -04:00
}
}
2020-01-28 19:45:18 -05:00
// Build the value.
2020-10-18 13:27:06 -04:00
$value = implode ( '/' , $value );
2009-06-18 13:40:40 -04:00
$selected = '' ;
if ( $value === $selected_zone ) {
$selected = 'selected="selected" ' ;
}
2017-11-30 18:11:00 -05:00
$structure [] = '<option ' . $selected . 'value="' . esc_attr ( $value ) . '">' . esc_html ( $display ) . '</option>' ;
2009-09-14 10:03:32 -04:00
2020-01-28 19:45:18 -05:00
// Close continent optgroup.
2017-11-30 18:11:00 -05:00
if ( ! empty ( $zone [ 'city' ] ) && ( ! isset ( $zonen [ $key + 1 ] ) || ( isset ( $zonen [ $key + 1 ] ) && $zonen [ $key + 1 ][ 'continent' ] !== $zone [ 'continent' ] ) ) ) {
2009-06-18 13:40:40 -04:00
$structure [] = '</optgroup>' ;
2009-03-09 20:50:00 -04:00
}
}
2020-01-28 19:45:18 -05:00
// Do UTC.
2017-11-30 18:11:00 -05:00
$structure [] = '<optgroup label="' . esc_attr__ ( 'UTC' ) . '">' ;
$selected = '' ;
if ( 'UTC' === $selected_zone ) {
2009-12-23 09:16:36 -05:00
$selected = 'selected="selected" ' ;
2017-11-30 18:11:00 -05:00
}
$structure [] = '<option ' . $selected . 'value="' . esc_attr ( 'UTC' ) . '">' . __ ( 'UTC' ) . '</option>' ;
2009-12-23 09:16:36 -05:00
$structure [] = '</optgroup>' ;
2020-01-28 19:45:18 -05:00
// Do manual UTC offsets.
2017-11-30 18:11:00 -05:00
$structure [] = '<optgroup label="' . esc_attr__ ( 'Manual Offsets' ) . '">' ;
$offset_range = array (
- 12 ,
- 11.5 ,
- 11 ,
- 10.5 ,
- 10 ,
- 9.5 ,
- 9 ,
- 8.5 ,
- 8 ,
- 7.5 ,
- 7 ,
- 6.5 ,
- 6 ,
- 5.5 ,
- 5 ,
- 4.5 ,
- 4 ,
- 3.5 ,
- 3 ,
- 2.5 ,
- 2 ,
- 1.5 ,
- 1 ,
- 0.5 ,
0 ,
0.5 ,
1 ,
1.5 ,
2 ,
2.5 ,
3 ,
3.5 ,
4 ,
4.5 ,
5 ,
5.5 ,
5.75 ,
6 ,
6.5 ,
7 ,
7.5 ,
8 ,
8.5 ,
8.75 ,
9 ,
9.5 ,
10 ,
10.5 ,
11 ,
11.5 ,
12 ,
12.75 ,
13 ,
13.75 ,
14 ,
);
2009-12-23 09:16:36 -05:00
foreach ( $offset_range as $offset ) {
2017-11-30 18:11:00 -05:00
if ( 0 <= $offset ) {
2009-12-23 09:16:36 -05:00
$offset_name = '+' . $offset ;
2017-11-30 18:11:00 -05:00
} else {
2009-12-23 09:16:36 -05:00
$offset_name = ( string ) $offset ;
2017-11-30 18:11:00 -05:00
}
2009-12-23 09:16:36 -05:00
$offset_value = $offset_name ;
2017-11-30 18:11:00 -05:00
$offset_name = str_replace ( array ( '.25' , '.5' , '.75' ), array ( ':15' , ':30' , ':45' ), $offset_name );
$offset_name = 'UTC' . $offset_name ;
2009-12-23 09:16:36 -05:00
$offset_value = 'UTC' . $offset_value ;
2017-11-30 18:11:00 -05:00
$selected = '' ;
if ( $offset_value === $selected_zone ) {
2009-12-23 09:16:36 -05:00
$selected = 'selected="selected" ' ;
2017-11-30 18:11:00 -05:00
}
$structure [] = '<option ' . $selected . 'value="' . esc_attr ( $offset_value ) . '">' . esc_html ( $offset_name ) . '</option>' ;
2010-01-15 17:11:12 -05:00
2009-12-23 09:16:36 -05:00
}
$structure [] = '</optgroup>' ;
2020-10-18 13:27:06 -04:00
return implode ( " \n " , $structure );
2009-03-09 20:50:00 -04:00
}
2009-05-04 05:33:58 -04:00
/**
2022-08-12 05:53:11 -04:00
* Strips close comment and close php tags from file headers used by WP .
2009-05-04 05:33:58 -04:00
*
2010-02-18 20:08:39 -05:00
* @ since 2.8 . 0
2014-07-07 02:19:14 -04:00
* @ access private
2010-02-18 20:08:39 -05:00
*
2014-09-29 09:28:16 -04:00
* @ see https :// core . trac . wordpress . org / ticket / 8497
2014-07-07 02:19:14 -04:00
*
* @ param string $str Header comment to clean up .
2010-02-18 20:08:39 -05:00
* @ return string
*/
2014-07-07 02:19:14 -04:00
function _cleanup_header_comment ( $str ) {
2017-11-30 18:11:00 -05:00
return trim ( preg_replace ( '/\s*(?:\*\/|\?>).*/' , '' , $str ) );
2009-05-04 05:33:58 -04:00
}
2009-07-24 03:23:11 -04:00
/**
2022-08-12 05:53:11 -04:00
* Permanently deletes comments or posts of any type that have held a status
2015-03-25 18:45:27 -04:00
* of 'trash' for the number of days defined in EMPTY_TRASH_DAYS .
*
* The default value of `EMPTY_TRASH_DAYS` is 30 ( days ) .
2009-09-14 10:03:32 -04:00
*
2009-07-24 03:23:11 -04:00
* @ since 2.9 . 0
2015-05-25 12:11:25 -04:00
*
2015-10-14 19:44:25 -04:00
* @ global wpdb $wpdb WordPress database abstraction object .
2009-07-24 03:23:11 -04:00
*/
function wp_scheduled_delete () {
2009-08-25 18:05:15 -04:00
global $wpdb ;
2012-09-25 01:26:19 -04:00
$delete_timestamp = time () - ( DAY_IN_SECONDS * EMPTY_TRASH_DAYS );
2009-09-14 10:03:32 -04:00
2017-11-30 18:11:00 -05:00
$posts_to_delete = $wpdb -> get_results ( $wpdb -> prepare ( " SELECT post_id FROM $wpdb->postmeta WHERE meta_key = '_wp_trash_meta_time' AND meta_value < %d " , $delete_timestamp ), ARRAY_A );
2009-09-14 10:03:32 -04:00
2009-08-25 18:05:15 -04:00
foreach ( ( array ) $posts_to_delete as $post ) {
2009-12-15 20:35:29 -05:00
$post_id = ( int ) $post [ 'post_id' ];
2017-11-30 18:11:00 -05:00
if ( ! $post_id ) {
2009-12-15 20:35:29 -05:00
continue ;
2017-11-30 18:11:00 -05:00
}
2009-12-15 20:35:29 -05:00
2017-11-30 18:11:00 -05:00
$del_post = get_post ( $post_id );
2009-12-15 20:35:29 -05:00
2020-05-16 14:42:12 -04:00
if ( ! $del_post || 'trash' !== $del_post -> post_status ) {
2017-11-30 18:11:00 -05:00
delete_post_meta ( $post_id , '_wp_trash_meta_status' );
delete_post_meta ( $post_id , '_wp_trash_meta_time' );
2009-12-15 20:35:29 -05:00
} else {
2017-11-30 18:11:00 -05:00
wp_delete_post ( $post_id );
2009-12-15 20:35:29 -05:00
}
2009-08-25 18:05:15 -04:00
}
2017-11-30 18:11:00 -05:00
$comments_to_delete = $wpdb -> get_results ( $wpdb -> prepare ( " SELECT comment_id FROM $wpdb->commentmeta WHERE meta_key = '_wp_trash_meta_time' AND meta_value < %d " , $delete_timestamp ), ARRAY_A );
2009-09-24 13:19:13 -04:00
2009-09-17 16:51:12 -04:00
foreach ( ( array ) $comments_to_delete as $comment ) {
2009-12-15 20:35:29 -05:00
$comment_id = ( int ) $comment [ 'comment_id' ];
2017-11-30 18:11:00 -05:00
if ( ! $comment_id ) {
2009-12-15 20:35:29 -05:00
continue ;
2017-11-30 18:11:00 -05:00
}
2009-12-15 20:35:29 -05:00
2017-11-30 18:11:00 -05:00
$del_comment = get_comment ( $comment_id );
2009-12-15 20:35:29 -05:00
2020-05-16 14:42:12 -04:00
if ( ! $del_comment || 'trash' !== $del_comment -> comment_approved ) {
2017-11-30 18:11:00 -05:00
delete_comment_meta ( $comment_id , '_wp_trash_meta_time' );
delete_comment_meta ( $comment_id , '_wp_trash_meta_status' );
2009-12-15 20:35:29 -05:00
} else {
2015-09-14 17:40:24 -04:00
wp_delete_comment ( $del_comment );
2009-12-15 20:35:29 -05:00
}
2009-07-30 09:39:34 -04:00
}
2009-07-24 03:23:11 -04:00
}
2009-10-15 17:07:00 -04:00
/**
2022-08-12 05:53:11 -04:00
* Retrieves metadata from a file .
2009-10-15 17:07:00 -04:00
*
2019-08-30 12:57:56 -04:00
* Searches for metadata in the first 8 KB of a file , such as a plugin or theme .
2011-07-21 13:48:25 -04:00
* Each piece of metadata must be on its own line . Fields can not span multiple
2010-12-05 22:44:36 -05:00
* lines , the value will get cut at the end of the first line .
2010-12-13 16:21:50 -05:00
*
2019-08-30 12:57:56 -04:00
* If the file data is not within that first 8 KB , then the author should correct
2010-12-05 22:44:36 -05:00
* their plugin file and move the data headers to the top .
2009-10-15 17:07:00 -04:00
*
2015-04-12 17:29:32 -04:00
* @ link https :// codex . wordpress . org / File_Header
2009-10-15 17:07:00 -04:00
*
* @ since 2.9 . 0
2014-11-23 12:57:22 -05:00
*
2018-03-05 16:50:31 -05:00
* @ param string $file Absolute path to the file .
2019-08-30 12:57:56 -04:00
* @ param array $default_headers List of headers , in the format `array( 'HeaderKey' => 'Header Name' )` .
2016-05-23 15:01:27 -04:00
* @ param string $context Optional . If specified adds filter hook { @ see 'extra_$context_headers' } .
2023-02-21 11:39:19 -05:00
* Default empty string .
2019-11-05 16:23:02 -05:00
* @ return string [] Array of file header values keyed by header name .
2009-10-15 17:07:00 -04:00
*/
function get_file_data ( $file , $default_headers , $context = '' ) {
2022-02-10 10:03:04 -05:00
// Pull only the first 8 KB of the file in.
$file_data = file_get_contents ( $file , false , null , 0 , 8 * KB_IN_BYTES );
2009-10-15 17:07:00 -04:00
2022-02-10 10:03:04 -05:00
if ( false === $file_data ) {
2020-09-30 08:20:03 -04:00
$file_data = '' ;
}
2009-10-15 17:07:00 -04:00
2012-04-29 21:25:29 -04:00
// Make sure we catch CR-only line endings.
$file_data = str_replace ( " \r " , " \n " , $file_data );
2014-04-13 20:20:14 -04:00
/**
2016-05-22 14:36:27 -04:00
* Filters extra file headers by context .
2014-04-13 20:20:14 -04:00
*
2014-11-30 07:10:23 -05:00
* The dynamic portion of the hook name , `$context` , refers to
* the context where extra headers might be loaded .
2014-04-13 20:20:14 -04:00
*
* @ since 2.9 . 0
*
* @ param array $extra_context_headers Empty array by default .
*/
2019-07-02 19:42:58 -04:00
$extra_headers = $context ? apply_filters ( " extra_ { $context } _headers " , array () ) : array ();
if ( $extra_headers ) {
2020-01-28 19:45:18 -05:00
$extra_headers = array_combine ( $extra_headers , $extra_headers ); // Keys equal values.
2017-11-30 18:11:00 -05:00
$all_headers = array_merge ( $extra_headers , ( array ) $default_headers );
2009-10-15 17:07:00 -04:00
} else {
$all_headers = $default_headers ;
}
foreach ( $all_headers as $field => $regex ) {
2021-06-18 10:03:58 -04:00
if ( preg_match ( '/^(?:[ \t]*<\?php)?[ \t\/*#@]*' . preg_quote ( $regex , '/' ) . ':(.*)$/mi' , $file_data , $match ) && $match [ 1 ] ) {
2012-03-02 16:07:31 -05:00
$all_headers [ $field ] = _cleanup_header_comment ( $match [ 1 ] );
2017-11-30 18:11:00 -05:00
} else {
2012-03-02 16:07:31 -05:00
$all_headers [ $field ] = '' ;
2017-11-30 18:11:00 -05:00
}
2009-10-15 17:07:00 -04:00
}
2012-03-02 16:07:31 -05:00
return $all_headers ;
2009-10-15 17:07:00 -04:00
}
2010-08-11 17:54:51 -04:00
2010-03-01 03:50:27 -05:00
/**
2011-07-21 13:48:25 -04:00
* Returns true .
2010-03-01 03:50:27 -05:00
*
2011-07-21 13:48:25 -04:00
* Useful for returning true to filters easily .
2010-03-01 03:50:27 -05:00
*
2010-05-14 12:46:53 -04:00
* @ since 3.0 . 0
2014-07-07 02:19:14 -04:00
*
2010-03-01 03:50:27 -05:00
* @ see __return_false ()
2014-07-07 02:19:14 -04:00
*
2015-05-25 12:11:25 -04:00
* @ return true True .
2010-03-01 03:50:27 -05:00
*/
2019-09-25 09:47:58 -04:00
function __return_true () { // phpcs:ignore WordPress.NamingConventions.ValidFunctionName.FunctionDoubleUnderscore,PHPCompatibility.FunctionNameRestrictions.ReservedFunctionNames.FunctionDoubleUnderscore
2010-03-01 03:50:27 -05:00
return true ;
}
2010-02-25 16:56:28 -05:00
/**
2011-07-21 13:48:25 -04:00
* Returns false .
2010-02-25 16:56:28 -05:00
*
2011-07-21 13:48:25 -04:00
* Useful for returning false to filters easily .
2010-03-01 03:50:27 -05:00
*
2010-05-14 12:46:53 -04:00
* @ since 3.0 . 0
2014-07-07 02:19:14 -04:00
*
2010-03-01 03:50:27 -05:00
* @ see __return_true ()
2014-07-07 02:19:14 -04:00
*
2015-05-25 12:11:25 -04:00
* @ return false False .
2010-02-25 16:56:28 -05:00
*/
2019-09-25 09:47:58 -04:00
function __return_false () { // phpcs:ignore WordPress.NamingConventions.ValidFunctionName.FunctionDoubleUnderscore,PHPCompatibility.FunctionNameRestrictions.ReservedFunctionNames.FunctionDoubleUnderscore
2010-02-25 16:56:28 -05:00
return false ;
2010-03-23 15:13:58 -04:00
}
2010-05-14 12:46:53 -04:00
/**
2011-07-21 13:48:25 -04:00
* Returns 0.
2010-05-14 12:46:53 -04:00
*
2011-07-21 13:48:25 -04:00
* Useful for returning 0 to filters easily .
2010-05-14 12:46:53 -04:00
*
* @ since 3.0 . 0
2014-07-07 02:19:14 -04:00
*
* @ return int 0.
2010-05-14 12:46:53 -04:00
*/
2019-09-25 09:47:58 -04:00
function __return_zero () { // phpcs:ignore WordPress.NamingConventions.ValidFunctionName.FunctionDoubleUnderscore,PHPCompatibility.FunctionNameRestrictions.ReservedFunctionNames.FunctionDoubleUnderscore
2010-05-14 12:46:53 -04:00
return 0 ;
}
2010-05-14 12:55:26 -04:00
/**
2011-07-21 13:48:25 -04:00
* Returns an empty array .
2010-05-14 12:55:26 -04:00
*
2011-07-21 13:48:25 -04:00
* Useful for returning an empty array to filters easily .
2010-05-14 12:55:26 -04:00
*
* @ since 3.0 . 0
2014-07-07 02:19:14 -04:00
*
* @ return array Empty array .
2010-05-14 12:55:26 -04:00
*/
2019-09-25 09:47:58 -04:00
function __return_empty_array () { // phpcs:ignore WordPress.NamingConventions.ValidFunctionName.FunctionDoubleUnderscore,PHPCompatibility.FunctionNameRestrictions.ReservedFunctionNames.FunctionDoubleUnderscore
2010-05-14 12:55:26 -04:00
return array ();
}
2011-12-20 15:58:30 -05:00
/**
* Returns null .
*
* Useful for returning null to filters easily .
*
2011-12-20 15:59:03 -05:00
* @ since 3.4 . 0
2014-07-07 02:19:14 -04:00
*
* @ return null Null value .
2011-12-20 15:58:30 -05:00
*/
2019-09-25 09:47:58 -04:00
function __return_null () { // phpcs:ignore WordPress.NamingConventions.ValidFunctionName.FunctionDoubleUnderscore,PHPCompatibility.FunctionNameRestrictions.ReservedFunctionNames.FunctionDoubleUnderscore
2011-12-20 15:58:30 -05:00
return null ;
}
2013-08-16 16:02:08 -04:00
/**
* Returns an empty string .
*
* Useful for returning an empty string to filters easily .
*
* @ since 3.7 . 0
2014-07-07 02:19:14 -04:00
*
2013-08-16 16:02:08 -04:00
* @ see __return_null ()
2014-07-07 02:19:14 -04:00
*
* @ return string Empty string .
2013-08-16 16:02:08 -04:00
*/
2019-09-25 09:47:58 -04:00
function __return_empty_string () { // phpcs:ignore WordPress.NamingConventions.ValidFunctionName.FunctionDoubleUnderscore,PHPCompatibility.FunctionNameRestrictions.ReservedFunctionNames.FunctionDoubleUnderscore
2013-08-16 16:02:08 -04:00
return '' ;
}
2010-03-23 15:13:58 -04:00
/**
2022-08-12 05:53:11 -04:00
* Sends a HTTP header to disable content type sniffing in browsers which support it .
2010-03-23 15:13:58 -04:00
*
* @ since 3.0 . 0
2014-07-07 02:19:14 -04:00
*
2016-06-10 00:50:33 -04:00
* @ see https :// blogs . msdn . com / ie / archive / 2008 / 07 / 02 / ie8 - security - part - v - comprehensive - protection . aspx
* @ see https :// src . chromium . org / viewvc / chrome ? view = rev & revision = 6985
2010-03-23 15:13:58 -04:00
*/
function send_nosniff_header () {
2019-07-09 01:45:58 -04:00
header ( 'X-Content-Type-Options: nosniff' );
2010-03-23 15:13:58 -04:00
}
2010-05-07 01:01:29 -04:00
/**
2022-08-12 05:53:11 -04:00
* Returns a MySQL expression for selecting the week number based on the start_of_week option .
2010-05-07 01:01:29 -04:00
*
2015-01-12 19:51:21 -05:00
* @ ignore
2010-05-07 01:01:29 -04:00
* @ since 3.0 . 0
2014-07-07 02:19:14 -04:00
*
* @ param string $column Database column .
* @ return string SQL clause .
2010-05-07 01:01:29 -04:00
*/
function _wp_mysql_week ( $column ) {
2019-07-02 19:42:58 -04:00
$start_of_week = ( int ) get_option ( 'start_of_week' );
switch ( $start_of_week ) {
2017-11-30 18:11:00 -05:00
case 1 :
return " WEEK( $column , 1 ) " ;
case 2 :
case 3 :
case 4 :
case 5 :
case 6 :
return " WEEK( DATE_SUB( $column , INTERVAL $start_of_week DAY ), 0 ) " ;
case 0 :
default :
return " WEEK( $column , 0 ) " ;
2010-05-07 01:01:29 -04:00
}
}
2010-10-14 11:09:04 -04:00
/**
2022-08-12 05:53:11 -04:00
* Finds hierarchy loops using a callback function that maps object IDs to parent IDs .
2010-10-14 11:09:04 -04:00
*
2010-10-19 03:38:42 -04:00
* @ since 3.1 . 0
2010-10-19 03:48:22 -04:00
* @ access private
2010-10-14 11:09:04 -04:00
*
2015-09-25 19:58:25 -04:00
* @ param callable $callback Function that accepts ( ID , $callback_args ) and outputs parent_ID .
2014-07-07 02:19:14 -04:00
* @ param int $start The ID to start the loop check at .
* @ param int $start_parent The parent_ID of $start to use instead of calling $callback ( $start ) .
2023-02-21 11:39:19 -05:00
* Use null to always use $callback .
* @ param array $callback_args Optional . Additional arguments to send to $callback . Default empty array .
2014-07-07 02:19:14 -04:00
* @ return array IDs of all members of loop .
2010-10-14 11:09:04 -04:00
*/
function wp_find_hierarchy_loop ( $callback , $start , $start_parent , $callback_args = array () ) {
$override = is_null ( $start_parent ) ? array () : array ( $start => $start_parent );
2019-07-02 19:42:58 -04:00
$arbitrary_loop_member = wp_find_hierarchy_loop_tortoise_hare ( $callback , $start , $override , $callback_args );
if ( ! $arbitrary_loop_member ) {
2010-10-14 11:09:04 -04:00
return array ();
2017-11-30 18:11:00 -05:00
}
2010-10-14 11:09:04 -04:00
return wp_find_hierarchy_loop_tortoise_hare ( $callback , $arbitrary_loop_member , $override , $callback_args , true );
}
/**
2022-08-12 05:53:11 -04:00
* Uses the " The Tortoise and the Hare " algorithm to detect loops .
2010-10-14 11:09:04 -04:00
*
* For every step of the algorithm , the hare takes two steps and the tortoise one .
* If the hare ever laps the tortoise , there must be a loop .
*
2010-10-19 03:38:42 -04:00
* @ since 3.1 . 0
* @ access private
2010-10-14 11:09:04 -04:00
*
2015-09-25 19:58:25 -04:00
* @ param callable $callback Function that accepts ( ID , callback_arg , ... ) and outputs parent_ID .
2014-07-07 02:19:14 -04:00
* @ param int $start The ID to start the loop check at .
* @ param array $override Optional . An array of ( ID => parent_ID , ... ) to use instead of $callback .
* Default empty array .
* @ param array $callback_args Optional . Additional arguments to send to $callback . Default empty array .
* @ param bool $_return_loop Optional . Return loop members or just detect presence of loop ? Only set
* to true if you already know the given $start is part of a loop ( otherwise
* the returned array might include branches ) . Default false .
* @ return mixed Scalar ID of some arbitrary member of the loop , or array of IDs of all members of loop if
* $_return_loop
2010-10-14 11:09:04 -04:00
*/
function wp_find_hierarchy_loop_tortoise_hare ( $callback , $start , $override = array (), $callback_args = array (), $_return_loop = false ) {
2019-07-02 19:42:58 -04:00
$tortoise = $start ;
$hare = $start ;
$evanescent_hare = $start ;
$return = array ();
2010-10-14 11:09:04 -04:00
2023-07-10 18:38:25 -04:00
// Set evanescent_hare to one past hare. Increment hare two steps.
2010-10-14 11:09:04 -04:00
while (
$tortoise
&&
2017-11-30 18:11:00 -05:00
( $evanescent_hare = isset ( $override [ $hare ] ) ? $override [ $hare ] : call_user_func_array ( $callback , array_merge ( array ( $hare ), $callback_args ) ) )
2010-10-14 11:09:04 -04:00
&&
2017-11-30 18:11:00 -05:00
( $hare = isset ( $override [ $evanescent_hare ] ) ? $override [ $evanescent_hare ] : call_user_func_array ( $callback , array_merge ( array ( $evanescent_hare ), $callback_args ) ) )
2010-10-14 11:09:04 -04:00
) {
2017-11-30 18:11:00 -05:00
if ( $_return_loop ) {
2019-07-02 19:42:58 -04:00
$return [ $tortoise ] = true ;
$return [ $evanescent_hare ] = true ;
$return [ $hare ] = true ;
2017-11-30 18:11:00 -05:00
}
2010-10-14 11:09:04 -04:00
2020-01-28 19:45:18 -05:00
// Tortoise got lapped - must be a loop.
2017-11-30 18:11:00 -05:00
if ( $tortoise == $evanescent_hare || $tortoise == $hare ) {
2010-10-14 11:09:04 -04:00
return $_return_loop ? $return : $tortoise ;
2017-11-30 18:11:00 -05:00
}
2010-10-14 11:09:04 -04:00
2020-01-28 19:45:18 -05:00
// Increment tortoise by one step.
2017-11-30 18:11:00 -05:00
$tortoise = isset ( $override [ $tortoise ] ) ? $override [ $tortoise ] : call_user_func_array ( $callback , array_merge ( array ( $tortoise ), $callback_args ) );
2010-10-14 11:09:04 -04:00
}
return false ;
}
2010-10-18 13:58:36 -04:00
2011-05-06 17:28:53 -04:00
/**
2022-08-12 05:53:11 -04:00
* Sends a HTTP header to limit rendering of pages to same origin iframes .
2011-05-06 17:28:53 -04:00
*
2011-05-25 11:47:17 -04:00
* @ since 3.1 . 3
2014-07-07 02:19:14 -04:00
*
2022-04-18 06:18:10 -04:00
* @ see https :// developer . mozilla . org / en - US / docs / Web / HTTP / Headers / X - Frame - Options
2011-05-06 17:28:53 -04:00
*/
function send_frame_options_header () {
2019-07-09 01:45:58 -04:00
header ( 'X-Frame-Options: SAMEORIGIN' );
2011-05-06 17:28:53 -04:00
}
2011-09-29 18:33:51 -04:00
/**
2022-08-12 05:53:11 -04:00
* Retrieves a list of protocols to allow in HTML attributes .
2011-09-29 18:33:51 -04:00
*
* @ since 3.3 . 0
2015-05-04 20:38:27 -04:00
* @ since 4.3 . 0 Added 'webcal' to the protocols array .
2016-09-30 09:15:28 -04:00
* @ since 4.7 . 0 Added 'urn' to the protocols array .
2019-09-18 19:38:55 -04:00
* @ since 5.3 . 0 Added 'sms' to the protocols array .
2020-09-26 17:02:04 -04:00
* @ since 5.6 . 0 Added 'irc6' and 'ircs' to the protocols array .
2014-07-07 02:19:14 -04:00
*
2011-09-29 18:33:51 -04:00
* @ see wp_kses ()
* @ see esc_url ()
*
2018-04-28 09:58:21 -04:00
* @ return string [] Array of allowed protocols . Defaults to an array containing 'http' , 'https' ,
2020-09-26 17:02:04 -04:00
* 'ftp' , 'ftps' , 'mailto' , 'news' , 'irc' , 'irc6' , 'ircs' , 'gopher' , 'nntp' , 'feed' ,
* 'telnet' , 'mms' , 'rtsp' , 'sms' , 'svn' , 'tel' , 'fax' , 'xmpp' , 'webcal' , and 'urn' .
2019-09-18 19:38:55 -04:00
* This covers all common link protocols , except for 'javascript' which should not
* be allowed for untrusted users .
2011-09-29 18:33:51 -04:00
*/
function wp_allowed_protocols () {
2015-05-29 11:43:29 -04:00
static $protocols = array ();
2011-09-29 18:33:51 -04:00
if ( empty ( $protocols ) ) {
2020-09-26 17:02:04 -04:00
$protocols = array ( 'http' , 'https' , 'ftp' , 'ftps' , 'mailto' , 'news' , 'irc' , 'irc6' , 'ircs' , 'gopher' , 'nntp' , 'feed' , 'telnet' , 'mms' , 'rtsp' , 'sms' , 'svn' , 'tel' , 'fax' , 'xmpp' , 'webcal' , 'urn' );
2017-10-24 09:25:55 -04:00
}
2014-04-13 20:20:14 -04:00
2017-10-24 09:25:55 -04:00
if ( ! did_action ( 'wp_loaded' ) ) {
2014-04-13 20:20:14 -04:00
/**
2016-05-22 14:36:27 -04:00
* Filters the list of protocols allowed in HTML attributes .
2014-05-05 16:08:16 -04:00
*
* @ since 3.0 . 0
2014-04-13 20:20:14 -04:00
*
2019-10-26 17:09:04 -04:00
* @ param string [] $protocols Array of allowed protocols e . g . 'http' , 'ftp' , 'tel' , and more .
2014-04-13 20:20:14 -04:00
*/
2017-10-24 09:25:55 -04:00
$protocols = array_unique ( ( array ) apply_filters ( 'kses_allowed_protocols' , $protocols ) );
2011-09-29 18:33:51 -04:00
}
return $protocols ;
}
2012-01-28 06:56:50 -05:00
/**
2022-04-28 05:46:21 -04:00
* Returns a comma - separated string or array of functions that have been called to get
2014-07-07 02:19:14 -04:00
* to the current point in code .
2012-01-28 07:37:08 -05:00
*
2013-11-06 05:17:09 -05:00
* @ since 3.4 . 0
2012-01-28 06:56:50 -05:00
*
2014-09-29 09:28:16 -04:00
* @ see https :// core . trac . wordpress . org / ticket / 19589
2014-07-07 02:19:14 -04:00
*
* @ param string $ignore_class Optional . A class to ignore all function calls within - useful
* when you want to just give info about the callee . Default null .
* @ param int $skip_frames Optional . A number of stack frames to skip - useful for unwinding
* back to the source of the issue . Default 0.
2022-04-28 05:46:21 -04:00
* @ param bool $pretty Optional . Whether you want a comma separated string instead of
* the raw array returned . Default true .
2014-07-07 02:19:14 -04:00
* @ return string | array Either a string containing a reversed comma separated trace or an array
* of individual calls .
2012-01-28 06:56:50 -05:00
*/
function wp_debug_backtrace_summary ( $ignore_class = null , $skip_frames = 0 , $pretty = true ) {
2018-03-08 12:08:31 -05:00
static $truncate_paths ;
2019-09-20 18:02:57 -04:00
$trace = debug_backtrace ( false );
2017-11-30 18:11:00 -05:00
$caller = array ();
2012-01-28 06:56:50 -05:00
$check_class = ! is_null ( $ignore_class );
2020-01-28 19:45:18 -05:00
$skip_frames ++ ; // Skip this function.
2012-01-28 06:56:50 -05:00
2018-03-08 12:08:31 -05:00
if ( ! isset ( $truncate_paths ) ) {
$truncate_paths = array (
wp_normalize_path ( WP_CONTENT_DIR ),
2018-08-16 21:51:36 -04:00
wp_normalize_path ( ABSPATH ),
2018-03-08 12:08:31 -05:00
);
}
2012-01-28 06:56:50 -05:00
foreach ( $trace as $call ) {
if ( $skip_frames > 0 ) {
$skip_frames -- ;
} elseif ( isset ( $call [ 'class' ] ) ) {
2017-11-30 18:11:00 -05:00
if ( $check_class && $ignore_class == $call [ 'class' ] ) {
2020-01-28 19:45:18 -05:00
continue ; // Filter out calls.
2017-11-30 18:11:00 -05:00
}
2012-01-28 06:56:50 -05:00
$caller [] = " { $call [ 'class' ] } { $call [ 'type' ] } { $call [ 'function' ] } " ;
} else {
2020-04-04 23:02:11 -04:00
if ( in_array ( $call [ 'function' ], array ( 'do_action' , 'apply_filters' , 'do_action_ref_array' , 'apply_filters_ref_array' ), true ) ) {
2012-01-28 06:56:50 -05:00
$caller [] = " { $call [ 'function' ] } (' { $call [ 'args' ][ 0 ] } ') " ;
2020-04-04 23:02:11 -04:00
} elseif ( in_array ( $call [ 'function' ], array ( 'include' , 'include_once' , 'require' , 'require_once' ), true ) ) {
2018-03-10 12:31:32 -05:00
$filename = isset ( $call [ 'args' ][ 0 ] ) ? $call [ 'args' ][ 0 ] : '' ;
$caller [] = $call [ 'function' ] . " (' " . str_replace ( $truncate_paths , '' , wp_normalize_path ( $filename ) ) . " ') " ;
2012-01-28 06:56:50 -05:00
} else {
$caller [] = $call [ 'function' ];
}
}
}
2017-11-30 18:11:00 -05:00
if ( $pretty ) {
2020-10-18 13:27:06 -04:00
return implode ( ', ' , array_reverse ( $caller ) );
2017-11-30 18:11:00 -05:00
} else {
2012-01-28 06:56:50 -05:00
return $caller ;
2017-11-30 18:11:00 -05:00
}
2012-01-28 07:37:08 -05:00
}
2012-02-14 10:09:35 -05:00
/**
2022-08-12 05:53:11 -04:00
* Retrieves IDs that are not already present in the cache .
2012-02-14 10:09:35 -05:00
*
* @ since 3.4 . 0
2022-08-25 21:03:14 -04:00
* @ since 6.1 . 0 This function is no longer marked as " private " .
2012-02-14 10:09:35 -05:00
*
2023-03-20 12:42:19 -04:00
* @ param int [] $object_ids Array of IDs .
* @ param string $cache_group The cache group to check against .
2018-03-25 15:33:31 -04:00
* @ return int [] Array of IDs not present in the cache .
2012-02-14 10:09:35 -05:00
*/
2023-03-20 12:42:19 -04:00
function _get_non_cached_ids ( $object_ids , $cache_group ) {
2023-03-14 11:53:18 -04:00
$object_ids = array_filter ( $object_ids , '_validate_cache_id' );
$object_ids = array_unique ( array_map ( 'intval' , $object_ids ), SORT_NUMERIC );
if ( empty ( $object_ids ) ) {
return array ();
}
2020-06-16 15:09:08 -04:00
$non_cached_ids = array ();
2023-03-20 12:42:19 -04:00
$cache_values = wp_cache_get_multiple ( $object_ids , $cache_group );
2020-06-16 15:09:08 -04:00
foreach ( $cache_values as $id => $value ) {
if ( ! $value ) {
$non_cached_ids [] = ( int ) $id ;
2012-02-14 10:09:35 -05:00
}
}
2020-06-16 15:09:08 -04:00
return $non_cached_ids ;
2012-02-14 10:09:35 -05:00
}
2023-03-14 11:53:18 -04:00
/**
2023-03-14 12:55:19 -04:00
* Checks whether the given cache ID is either an integer or an integer - like string .
*
* Both `16` and `"16"` are considered valid , other numeric types and numeric strings
* ( `16.3` and `"16.3"` ) are considered invalid .
2023-03-14 11:53:18 -04:00
*
* @ since 6.3 . 0
*
2023-03-14 12:55:19 -04:00
* @ param mixed $object_id The cache ID to validate .
* @ return bool Whether the given $object_id is a valid cache ID .
2023-03-14 11:53:18 -04:00
*/
function _validate_cache_id ( $object_id ) {
2023-03-14 12:55:19 -04:00
/*
* filter_var () could be used here , but the `filter` PHP extension
* is considered optional and may not be available .
*/
2023-03-14 11:53:18 -04:00
if ( is_int ( $object_id )
|| ( is_string ( $object_id ) && ( string ) ( int ) $object_id === $object_id ) ) {
return true ;
}
2023-03-14 12:55:19 -04:00
/* translators: %s: The type of the given object ID. */
$message = sprintf ( __ ( 'Object ID must be an integer, %s given.' ), gettype ( $object_id ) );
2023-03-14 11:53:18 -04:00
_doing_it_wrong ( '_get_non_cached_ids' , $message , '6.3.0' );
return false ;
}
2012-04-11 20:16:37 -04:00
/**
2022-08-12 05:53:11 -04:00
* Tests if the current device has the capability to upload files .
2012-04-11 20:16:37 -04:00
*
* @ since 3.4 . 0
* @ access private
*
2015-06-26 20:45:24 -04:00
* @ return bool Whether the device is able to upload files .
2012-04-11 20:16:37 -04:00
*/
function _device_can_upload () {
2017-11-30 18:11:00 -05:00
if ( ! wp_is_mobile () ) {
2012-04-11 20:16:37 -04:00
return true ;
2017-11-30 18:11:00 -05:00
}
2012-04-11 20:16:37 -04:00
$ua = $_SERVER [ 'HTTP_USER_AGENT' ];
2012-05-03 12:41:59 -04: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 10:36:26 -04:00
if ( str_contains ( $ua , 'iPhone' )
|| str_contains ( $ua , 'iPad' )
|| str_contains ( $ua , 'iPod' ) ) {
2012-06-26 16:39:04 -04:00
return preg_match ( '#OS ([\d_]+) like Mac OS X#' , $ua , $version ) && version_compare ( $version [ 1 ], '6' , '>=' );
2012-04-11 20:16:37 -04:00
}
2012-06-26 16:39:04 -04:00
return true ;
2012-04-11 20:16:37 -04:00
}
2012-10-01 16:59:06 -04:00
/**
2022-08-12 05:53:11 -04:00
* Tests if a given path is a stream URL
2012-10-01 16:59:06 -04:00
*
2016-12-27 04:21:44 -05:00
* @ since 3.5 . 0
*
2014-07-07 02:19:14 -04:00
* @ param string $path The resource path or URL .
* @ return bool True if the path is a stream URL .
2012-10-01 16:59:06 -04:00
*/
function wp_is_stream ( $path ) {
2019-01-09 04:51:54 -05:00
$scheme_separator = strpos ( $path , '://' );
if ( false === $scheme_separator ) {
2020-01-28 19:45:18 -05:00
// $path isn't a stream.
2018-07-17 03:54:25 -04:00
return false ;
}
2019-01-09 04:51:54 -05:00
$stream = substr ( $path , 0 , $scheme_separator );
2012-10-01 16:59:06 -04:00
2019-01-09 04:51:54 -05:00
return in_array ( $stream , stream_get_wrappers (), true );
2012-10-01 16:59:06 -04:00
}
2012-09-20 06:46:50 -04:00
/**
2022-08-12 05:53:11 -04:00
* Tests if the supplied date is valid for the Gregorian calendar .
2012-09-20 06:46:50 -04:00
*
* @ since 3.5 . 0
*
2020-01-19 22:14:06 -05:00
* @ link https :// www . php . net / manual / en / function . checkdate . php
2014-06-29 23:47:16 -04:00
*
2020-06-20 08:58:10 -04:00
* @ param int $month Month number .
* @ param int $day Day number .
* @ param int $year Year number .
* @ param string $source_date The date to filter .
2014-07-07 02:19:14 -04:00
* @ return bool True if valid date , false if not valid date .
2012-09-20 06:46:50 -04:00
*/
function wp_checkdate ( $month , $day , $year , $source_date ) {
2014-04-13 20:20:14 -04:00
/**
2016-05-22 14:36:27 -04:00
* Filters whether the given date is valid for the Gregorian calendar .
2014-04-13 20:20:14 -04:00
*
* @ since 3.5 . 0
*
* @ param bool $checkdate Whether the given date is valid .
* @ param string $source_date Date to check .
*/
2012-09-20 06:46:50 -04:00
return apply_filters ( 'wp_checkdate' , checkdate ( $month , $day , $year ), $source_date );
2013-02-28 03:57:17 -05:00
}
/**
2022-08-12 05:53:11 -04:00
* Loads the auth check for monitoring whether the user is still logged in .
2013-02-28 03:57:17 -05:00
*
2013-07-18 15:06:35 -04:00
* Can be disabled with remove_action ( 'admin_enqueue_scripts' , 'wp_auth_check_load' );
*
* This is disabled for certain screens where a login screen could cause an
2016-05-23 15:01:27 -04:00
* inconvenient interruption . A filter called { @ see 'wp_auth_check_load' } can be used
2013-07-18 15:06:35 -04:00
* for fine - grained control .
2013-02-28 03:57:17 -05:00
*
2013-07-18 15:06:35 -04:00
* @ since 3.6 . 0
2013-02-28 03:57:17 -05:00
*/
function wp_auth_check_load () {
2017-11-30 18:11:00 -05:00
if ( ! is_admin () && ! is_user_logged_in () ) {
2013-07-18 15:06:35 -04:00
return ;
2017-11-30 18:11:00 -05:00
}
2013-02-28 20:55:33 -05:00
2017-11-30 18:11:00 -05:00
if ( defined ( 'IFRAME_REQUEST' ) ) {
2013-03-27 04:43:11 -04:00
return ;
2017-11-30 18:11:00 -05:00
}
2013-03-27 04:43:11 -04:00
2013-07-18 15:06:35 -04:00
$screen = get_current_screen ();
$hidden = array ( 'update' , 'update-network' , 'update-core' , 'update-core-network' , 'upgrade' , 'upgrade-network' , 'network' );
2020-04-04 23:02:11 -04:00
$show = ! in_array ( $screen -> id , $hidden , true );
2013-03-27 04:43:11 -04:00
2014-04-13 20:20:14 -04:00
/**
2016-05-22 14:36:27 -04:00
* Filters whether to load the authentication check .
2014-04-13 20:20:14 -04:00
*
2020-06-26 14:49:09 -04:00
* Returning a falsey value from the filter will effectively short - circuit
2014-07-07 02:19:14 -04:00
* loading the authentication check .
*
2014-04-13 20:20:14 -04:00
* @ since 3.6 . 0
*
* @ param bool $show Whether to load the authentication check .
* @ param WP_Screen $screen The current screen object .
*/
2013-07-18 15:06:35 -04:00
if ( apply_filters ( 'wp_auth_check_load' , $show , $screen ) ) {
wp_enqueue_style ( 'wp-auth-check' );
wp_enqueue_script ( 'wp-auth-check' );
add_action ( 'admin_print_footer_scripts' , 'wp_auth_check_html' , 5 );
add_action ( 'wp_print_footer_scripts' , 'wp_auth_check_html' , 5 );
2013-03-27 04:43:11 -04:00
}
2013-02-28 20:55:33 -05:00
}
/**
2022-08-12 05:53:11 -04:00
* Outputs the HTML that shows the wp - login dialog when the user is no longer logged in .
2013-07-18 15:06:35 -04:00
*
* @ since 3.6 . 0
2013-03-01 12:58:43 -05:00
*/
2013-03-27 04:43:11 -04:00
function wp_auth_check_html () {
2017-11-30 18:11:00 -05:00
$login_url = wp_login_url ();
2013-03-27 04:43:11 -04:00
$current_domain = ( is_ssl () ? 'https://' : 'http://' ) . $_SERVER [ 'HTTP_HOST' ];
Code Modernization: Replace usage of `strpos()` with `str_starts_with()`.
`str_starts_with()` was introduced in PHP 8.0 to perform a case-sensitive check indicating if the string to search in (haystack) begins with the given substring (needle).
WordPress core includes a polyfill for `str_starts_with()` on PHP < 8.0 as of WordPress 5.9.
This commit replaces `0 === strpos( ... )` with `str_starts_with()` in core files, making the code more readable and consistent, as well as improving performance.
While `strpos()` is slightly faster than the polyfill on PHP < 8.0, `str_starts_with()` is noticeably faster on PHP 8.0+, as it is optimized to avoid unnecessarily searching along the whole haystack if it does not find the needle.
Follow-up to [52039], [52040], [52326].
Props spacedmonkey, costdev, sabernhardt, mukesh27, desrosj, jorbin, TobiasBg, ayeshrajans, lgadzhev, SergeyBiryukov.
Fixes #58012.
Built from https://develop.svn.wordpress.org/trunk@55703
git-svn-id: http://core.svn.wordpress.org/trunk@55215 1a063a9b-81f0-0310-95a4-ce76da25c4cd
2023-05-02 11:45:22 -04:00
$same_domain = str_starts_with ( $login_url , $current_domain );
2013-04-05 19:28:40 -04:00
2014-04-13 20:20:14 -04:00
/**
2016-05-22 14:36:27 -04:00
* Filters whether the authentication check originated at the same domain .
2014-04-13 20:20:14 -04:00
*
* @ since 3.6 . 0
*
* @ param bool $same_domain Whether the authentication check originated at the same domain .
*/
2013-03-27 04:43:11 -04:00
$same_domain = apply_filters ( 'wp_auth_check_same_domain' , $same_domain );
2017-11-30 18:11:00 -05:00
$wrap_class = $same_domain ? 'hidden' : 'hidden fallback' ;
2013-03-27 04:43:11 -04:00
2013-02-28 20:55:33 -05:00
?>
2013-03-27 04:43:11 -04:00
< div id = " wp-auth-check-wrap " class = " <?php echo $wrap_class ; ?> " >
< div id = " wp-auth-check-bg " ></ div >
< div id = " wp-auth-check " >
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 12:10:21 -05:00
< button type = " button " class = " wp-auth-check-close button-link " >< span class = " screen-reader-text " >
< ? php
/* translators: Hidden accessibility text. */
_e ( 'Close dialog' );
?>
</ span ></ button >
2013-03-27 04:43:11 -04:00
< ? php
if ( $same_domain ) {
2017-11-30 18:11:00 -05:00
$login_src = add_query_arg (
array (
'interim-login' => '1' ,
'wp_lang' => get_user_locale (),
2018-08-16 21:51:36 -04:00
),
$login_url
2017-11-30 18:11:00 -05:00
);
2013-03-27 04:43:11 -04:00
?>
2017-10-02 19:21:47 -04:00
< div id = " wp-auth-check-form " class = " loading " data - src = " <?php echo esc_url( $login_src ); ?> " ></ div >
2013-03-27 04:43:11 -04:00
< ? php
}
?>
< div class = " wp-auth-fallback " >
2017-11-30 18:11:00 -05:00
< p >< b class = " wp-auth-fallback-expired " tabindex = " 0 " >< ? php _e ( 'Session expired' ); ?> </b></p>
< p >< a href = " <?php echo esc_url( $login_url ); ?> " target = " _blank " >< ? php _e ( 'Please log in again.' ); ?> </a>
2018-05-05 05:45:22 -04:00
< ? php _e ( 'The login page will open in a new tab. After logging in you can close it and return to this page.' ); ?> </p>
2013-03-27 04:43:11 -04:00
</ div >
</ div >
</ div >
2013-02-28 20:55:33 -05:00
< ? php
}
/**
2022-08-12 05:53:11 -04:00
* Checks whether a user is still logged in , for the heartbeat .
2013-07-18 15:06:35 -04:00
*
* Send a result that shows a log - in box if the user is no longer logged in ,
* or if their cookie is within the grace period .
2013-02-28 20:55:33 -05:00
*
* @ since 3.6 . 0
2014-06-29 23:47:16 -04:00
*
2015-05-25 12:11:25 -04:00
* @ global int $login_grace_period
*
* @ param array $response The Heartbeat response .
2019-11-03 17:23:01 -05:00
* @ return array The Heartbeat response with 'wp-auth-check' value set .
2013-02-28 20:55:33 -05:00
*/
2014-02-09 17:34:11 -05:00
function wp_auth_check ( $response ) {
2013-07-18 15:06:35 -04:00
$response [ 'wp-auth-check' ] = is_user_logged_in () && empty ( $GLOBALS [ 'login_grace_period' ] );
return $response ;
2013-02-28 03:57:17 -05:00
}
2013-03-16 01:25:44 -04:00
/**
2022-08-12 05:53:11 -04:00
* Returns RegEx body to liberally match an opening HTML tag .
2014-07-07 02:19:14 -04:00
*
* Matches an opening HTML tag that :
2013-03-16 01:25:44 -04:00
* 1. Is self - closing or
* 2. Has no body but has a closing tag of the same name or
* 3. Contains a body and a closing tag of the same name
*
2014-07-07 02:19:14 -04:00
* Note : this RegEx does not balance inner tags and does not attempt
* to produce valid HTML
2013-03-16 01:25:44 -04:00
*
* @ since 3.6 . 0
*
2014-07-07 02:19:14 -04:00
* @ param string $tag An HTML tag name . Example : 'video' .
* @ return string Tag RegEx .
2013-03-16 01:25:44 -04:00
*/
function get_tag_regex ( $tag ) {
2017-11-30 18:11:00 -05:00
if ( empty ( $tag ) ) {
2020-03-04 07:05:05 -05:00
return '' ;
2017-11-30 18:11:00 -05:00
}
2013-04-22 18:11:42 -04:00
return sprintf ( '<%1$s[^<]*(?:>[\s\S]*<\/%1$s>|\s*\/>)' , tag_escape ( $tag ) );
2013-03-27 04:43:11 -04:00
}
2013-06-25 15:03:17 -04:00
/**
2022-08-12 05:53:11 -04:00
* Retrieves a canonical form of the provided charset appropriate for passing to PHP
2020-06-28 10:02:06 -04:00
* functions such as htmlspecialchars () and charset HTML attributes .
2013-06-25 15:03:17 -04:00
*
* @ since 3.6 . 0
2014-07-07 02:19:14 -04:00
* @ access private
*
2014-09-29 09:28:16 -04:00
* @ see https :// core . trac . wordpress . org / ticket / 23688
2013-06-25 15:03:17 -04:00
*
2014-07-07 02:19:14 -04:00
* @ param string $charset A charset name .
* @ return string The canonical form of the charset .
2013-06-25 15:03:17 -04:00
*/
function _canonical_charset ( $charset ) {
2017-11-30 18:11:00 -05:00
if ( 'utf-8' === strtolower ( $charset ) || 'utf8' === strtolower ( $charset ) ) {
2016-10-17 19:54:30 -04:00
2013-06-25 15:03:17 -04:00
return 'UTF-8' ;
2016-10-17 19:54:30 -04:00
}
if ( 'iso-8859-1' === strtolower ( $charset ) || 'iso8859-1' === strtolower ( $charset ) ) {
2013-06-25 15:03:17 -04:00
return 'ISO-8859-1' ;
2016-10-17 19:54:30 -04:00
}
2013-06-25 15:03:17 -04:00
return $charset ;
2013-07-12 19:32:32 -04:00
}
2013-09-11 03:23:08 -04:00
/**
2022-08-12 05:53:11 -04:00
* Sets the mbstring internal encoding to a binary safe encoding when func_overload
2014-07-07 02:19:14 -04:00
* is enabled .
2013-09-11 03:23:08 -04:00
*
2014-07-07 02:19:14 -04:00
* When mbstring . func_overload is in use for multi - byte encodings , the results from
* strlen () and similar functions respect the utf8 characters , causing binary data
* to return incorrect lengths .
2013-09-11 03:23:08 -04:00
*
2014-07-07 02:19:14 -04:00
* This function overrides the mbstring encoding to a binary - safe encoding , and
* resets it to the users expected encoding afterwards through the
* `reset_mbstring_encoding` function .
2013-09-11 03:23:08 -04:00
*
2014-07-07 02:19:14 -04:00
* It is safe to recursively call this function , however each
* `mbstring_binary_safe_encoding()` call must be followed up with an equal number
* of `reset_mbstring_encoding()` calls .
2013-09-11 03:23:08 -04:00
*
* @ since 3.7 . 0
*
2014-07-07 02:19:14 -04:00
* @ see reset_mbstring_encoding ()
*
* @ param bool $reset Optional . Whether to reset the encoding back to a previously - set encoding .
* Default false .
2013-09-11 03:23:08 -04:00
*/
function mbstring_binary_safe_encoding ( $reset = false ) {
2017-11-30 18:11:00 -05:00
static $encodings = array ();
2013-09-11 03:23:08 -04:00
static $overloaded = null ;
2017-11-30 18:11:00 -05:00
if ( is_null ( $overloaded ) ) {
2021-05-26 12:05:59 -04:00
if ( function_exists ( 'mb_internal_encoding' )
&& ( ( int ) ini_get ( 'mbstring.func_overload' ) & 2 ) // phpcs:ignore PHPCompatibility.IniDirectives.RemovedIniDirectives.mbstring_func_overloadDeprecated
) {
$overloaded = true ;
} else {
$overloaded = false ;
}
2017-11-30 18:11:00 -05:00
}
2013-09-11 03:23:08 -04:00
2017-11-30 18:11:00 -05:00
if ( false === $overloaded ) {
2013-09-11 03:23:08 -04:00
return ;
2017-11-30 18:11:00 -05:00
}
2013-09-11 03:23:08 -04:00
if ( ! $reset ) {
$encoding = mb_internal_encoding ();
array_push ( $encodings , $encoding );
mb_internal_encoding ( 'ISO-8859-1' );
}
if ( $reset && $encodings ) {
$encoding = array_pop ( $encodings );
mb_internal_encoding ( $encoding );
}
}
/**
2022-08-12 05:53:11 -04:00
* Resets the mbstring internal encoding to a users previously set encoding .
2013-09-11 03:23:08 -04:00
*
* @ see mbstring_binary_safe_encoding ()
*
* @ since 3.7 . 0
*/
function reset_mbstring_encoding () {
mbstring_binary_safe_encoding ( true );
2013-09-14 10:34:09 -04:00
}
2014-05-22 14:34:15 -04:00
/**
2022-08-12 05:53:11 -04:00
* Filters / validates a variable as a boolean .
2014-11-03 10:55:23 -05:00
*
Code Modernization: Rename parameters that use reserved keywords in `wp-includes/functions.php`.
While using reserved PHP keywords as parameter name labels is allowed, in the context of function calls using named parameters in PHP 8.0+, this will easily lead to confusion. To avoid that, it is recommended not to use reserved keywords as function parameter names.
This commit:
* Renames the `$echo` parameter to `$display` in:
* `wp_nonce_field()`
* `wp_referer_field()`
* `wp_original_referer_field()`
* Renames the `$string` parameter to `$input_string` in
* `_wp_json_convert_string()`
* `_wp_to_kebab_case()`
* Renames the `$list` parameter to `$input_list` in:
* `wp_parse_list()`
* `wp_parse_id_list()`
* `wp_parse_slug_list()`
* `wp_filter_object_list()`
* `wp_list_filter()`
* `wp_list_pluck()`
* `wp_list_sort()`
* Renames the `$array` parameter to `$input_array` in:
* `add_magic_quotes()`
* `wp_array_slice_assoc()`
* `_wp_array_get()`
* `_wp_array_set()`
* Renames the `$function` parameter to `$function_name` in:
* `_deprecated_function()`
* `_deprecated_argument()`
* `_doing_it_wrong()`
* Renames the `$class` parameter to `$class_name` in `_deprecated_constructor()`.
* Renames the `$default` parameter to `$default_value` in `apache_mod_loaded()`.
* Renames the `$var` parameter to `$value` in `wp_validate_boolean()`.
* Amends the `$input` parameter in `wp_parse_str()` for consistency.
Follow-up to [52946], [52996], [52997], [52998], [53003], [53014], [53029], [53039], [53116], [53117], [53137], [53174], [53184], [53185], [53192], [53193], [53198], [53203], [53207], [53215], [53216], [53220], [53230], [53232], [53236], [53239], [53240], [53242], [53243], [53245], [53246], [53257], [53269], [53270], [53271], [53272], [53273], [53274], [53275], [53276], [53277], [53281], [53283], [53284], [53285], [53287], [53364], [53365], [54927].
Props jrf, aristath, poena, justinahinon, SergeyBiryukov.
See #56788.
Built from https://develop.svn.wordpress.org/trunk@54929
git-svn-id: http://core.svn.wordpress.org/trunk@54481 1a063a9b-81f0-0310-95a4-ce76da25c4cd
2022-12-03 10:07:14 -05:00
* Alternative to `filter_var( $value, FILTER_VALIDATE_BOOLEAN )` .
2014-05-22 14:34:15 -04:00
*
* @ since 4.0 . 0
*
Code Modernization: Rename parameters that use reserved keywords in `wp-includes/functions.php`.
While using reserved PHP keywords as parameter name labels is allowed, in the context of function calls using named parameters in PHP 8.0+, this will easily lead to confusion. To avoid that, it is recommended not to use reserved keywords as function parameter names.
This commit:
* Renames the `$echo` parameter to `$display` in:
* `wp_nonce_field()`
* `wp_referer_field()`
* `wp_original_referer_field()`
* Renames the `$string` parameter to `$input_string` in
* `_wp_json_convert_string()`
* `_wp_to_kebab_case()`
* Renames the `$list` parameter to `$input_list` in:
* `wp_parse_list()`
* `wp_parse_id_list()`
* `wp_parse_slug_list()`
* `wp_filter_object_list()`
* `wp_list_filter()`
* `wp_list_pluck()`
* `wp_list_sort()`
* Renames the `$array` parameter to `$input_array` in:
* `add_magic_quotes()`
* `wp_array_slice_assoc()`
* `_wp_array_get()`
* `_wp_array_set()`
* Renames the `$function` parameter to `$function_name` in:
* `_deprecated_function()`
* `_deprecated_argument()`
* `_doing_it_wrong()`
* Renames the `$class` parameter to `$class_name` in `_deprecated_constructor()`.
* Renames the `$default` parameter to `$default_value` in `apache_mod_loaded()`.
* Renames the `$var` parameter to `$value` in `wp_validate_boolean()`.
* Amends the `$input` parameter in `wp_parse_str()` for consistency.
Follow-up to [52946], [52996], [52997], [52998], [53003], [53014], [53029], [53039], [53116], [53117], [53137], [53174], [53184], [53185], [53192], [53193], [53198], [53203], [53207], [53215], [53216], [53220], [53230], [53232], [53236], [53239], [53240], [53242], [53243], [53245], [53246], [53257], [53269], [53270], [53271], [53272], [53273], [53274], [53275], [53276], [53277], [53281], [53283], [53284], [53285], [53287], [53364], [53365], [54927].
Props jrf, aristath, poena, justinahinon, SergeyBiryukov.
See #56788.
Built from https://develop.svn.wordpress.org/trunk@54929
git-svn-id: http://core.svn.wordpress.org/trunk@54481 1a063a9b-81f0-0310-95a4-ce76da25c4cd
2022-12-03 10:07:14 -05:00
* @ param mixed $value Boolean value to validate .
2014-07-07 02:19:14 -04:00
* @ return bool Whether the value is validated .
2014-05-22 14:34:15 -04:00
*/
Code Modernization: Rename parameters that use reserved keywords in `wp-includes/functions.php`.
While using reserved PHP keywords as parameter name labels is allowed, in the context of function calls using named parameters in PHP 8.0+, this will easily lead to confusion. To avoid that, it is recommended not to use reserved keywords as function parameter names.
This commit:
* Renames the `$echo` parameter to `$display` in:
* `wp_nonce_field()`
* `wp_referer_field()`
* `wp_original_referer_field()`
* Renames the `$string` parameter to `$input_string` in
* `_wp_json_convert_string()`
* `_wp_to_kebab_case()`
* Renames the `$list` parameter to `$input_list` in:
* `wp_parse_list()`
* `wp_parse_id_list()`
* `wp_parse_slug_list()`
* `wp_filter_object_list()`
* `wp_list_filter()`
* `wp_list_pluck()`
* `wp_list_sort()`
* Renames the `$array` parameter to `$input_array` in:
* `add_magic_quotes()`
* `wp_array_slice_assoc()`
* `_wp_array_get()`
* `_wp_array_set()`
* Renames the `$function` parameter to `$function_name` in:
* `_deprecated_function()`
* `_deprecated_argument()`
* `_doing_it_wrong()`
* Renames the `$class` parameter to `$class_name` in `_deprecated_constructor()`.
* Renames the `$default` parameter to `$default_value` in `apache_mod_loaded()`.
* Renames the `$var` parameter to `$value` in `wp_validate_boolean()`.
* Amends the `$input` parameter in `wp_parse_str()` for consistency.
Follow-up to [52946], [52996], [52997], [52998], [53003], [53014], [53029], [53039], [53116], [53117], [53137], [53174], [53184], [53185], [53192], [53193], [53198], [53203], [53207], [53215], [53216], [53220], [53230], [53232], [53236], [53239], [53240], [53242], [53243], [53245], [53246], [53257], [53269], [53270], [53271], [53272], [53273], [53274], [53275], [53276], [53277], [53281], [53283], [53284], [53285], [53287], [53364], [53365], [54927].
Props jrf, aristath, poena, justinahinon, SergeyBiryukov.
See #56788.
Built from https://develop.svn.wordpress.org/trunk@54929
git-svn-id: http://core.svn.wordpress.org/trunk@54481 1a063a9b-81f0-0310-95a4-ce76da25c4cd
2022-12-03 10:07:14 -05:00
function wp_validate_boolean ( $value ) {
if ( is_bool ( $value ) ) {
return $value ;
2014-05-22 14:34:15 -04:00
}
Code Modernization: Rename parameters that use reserved keywords in `wp-includes/functions.php`.
While using reserved PHP keywords as parameter name labels is allowed, in the context of function calls using named parameters in PHP 8.0+, this will easily lead to confusion. To avoid that, it is recommended not to use reserved keywords as function parameter names.
This commit:
* Renames the `$echo` parameter to `$display` in:
* `wp_nonce_field()`
* `wp_referer_field()`
* `wp_original_referer_field()`
* Renames the `$string` parameter to `$input_string` in
* `_wp_json_convert_string()`
* `_wp_to_kebab_case()`
* Renames the `$list` parameter to `$input_list` in:
* `wp_parse_list()`
* `wp_parse_id_list()`
* `wp_parse_slug_list()`
* `wp_filter_object_list()`
* `wp_list_filter()`
* `wp_list_pluck()`
* `wp_list_sort()`
* Renames the `$array` parameter to `$input_array` in:
* `add_magic_quotes()`
* `wp_array_slice_assoc()`
* `_wp_array_get()`
* `_wp_array_set()`
* Renames the `$function` parameter to `$function_name` in:
* `_deprecated_function()`
* `_deprecated_argument()`
* `_doing_it_wrong()`
* Renames the `$class` parameter to `$class_name` in `_deprecated_constructor()`.
* Renames the `$default` parameter to `$default_value` in `apache_mod_loaded()`.
* Renames the `$var` parameter to `$value` in `wp_validate_boolean()`.
* Amends the `$input` parameter in `wp_parse_str()` for consistency.
Follow-up to [52946], [52996], [52997], [52998], [53003], [53014], [53029], [53039], [53116], [53117], [53137], [53174], [53184], [53185], [53192], [53193], [53198], [53203], [53207], [53215], [53216], [53220], [53230], [53232], [53236], [53239], [53240], [53242], [53243], [53245], [53246], [53257], [53269], [53270], [53271], [53272], [53273], [53274], [53275], [53276], [53277], [53281], [53283], [53284], [53285], [53287], [53364], [53365], [54927].
Props jrf, aristath, poena, justinahinon, SergeyBiryukov.
See #56788.
Built from https://develop.svn.wordpress.org/trunk@54929
git-svn-id: http://core.svn.wordpress.org/trunk@54481 1a063a9b-81f0-0310-95a4-ce76da25c4cd
2022-12-03 10:07:14 -05:00
if ( is_string ( $value ) && 'false' === strtolower ( $value ) ) {
2014-05-22 14:34:15 -04:00
return false ;
}
Code Modernization: Rename parameters that use reserved keywords in `wp-includes/functions.php`.
While using reserved PHP keywords as parameter name labels is allowed, in the context of function calls using named parameters in PHP 8.0+, this will easily lead to confusion. To avoid that, it is recommended not to use reserved keywords as function parameter names.
This commit:
* Renames the `$echo` parameter to `$display` in:
* `wp_nonce_field()`
* `wp_referer_field()`
* `wp_original_referer_field()`
* Renames the `$string` parameter to `$input_string` in
* `_wp_json_convert_string()`
* `_wp_to_kebab_case()`
* Renames the `$list` parameter to `$input_list` in:
* `wp_parse_list()`
* `wp_parse_id_list()`
* `wp_parse_slug_list()`
* `wp_filter_object_list()`
* `wp_list_filter()`
* `wp_list_pluck()`
* `wp_list_sort()`
* Renames the `$array` parameter to `$input_array` in:
* `add_magic_quotes()`
* `wp_array_slice_assoc()`
* `_wp_array_get()`
* `_wp_array_set()`
* Renames the `$function` parameter to `$function_name` in:
* `_deprecated_function()`
* `_deprecated_argument()`
* `_doing_it_wrong()`
* Renames the `$class` parameter to `$class_name` in `_deprecated_constructor()`.
* Renames the `$default` parameter to `$default_value` in `apache_mod_loaded()`.
* Renames the `$var` parameter to `$value` in `wp_validate_boolean()`.
* Amends the `$input` parameter in `wp_parse_str()` for consistency.
Follow-up to [52946], [52996], [52997], [52998], [53003], [53014], [53029], [53039], [53116], [53117], [53137], [53174], [53184], [53185], [53192], [53193], [53198], [53203], [53207], [53215], [53216], [53220], [53230], [53232], [53236], [53239], [53240], [53242], [53243], [53245], [53246], [53257], [53269], [53270], [53271], [53272], [53273], [53274], [53275], [53276], [53277], [53281], [53283], [53284], [53285], [53287], [53364], [53365], [54927].
Props jrf, aristath, poena, justinahinon, SergeyBiryukov.
See #56788.
Built from https://develop.svn.wordpress.org/trunk@54929
git-svn-id: http://core.svn.wordpress.org/trunk@54481 1a063a9b-81f0-0310-95a4-ce76da25c4cd
2022-12-03 10:07:14 -05:00
return ( bool ) $value ;
2014-06-09 22:03:14 -04:00
}
2015-02-27 11:51:25 -05:00
/**
2022-08-12 05:53:11 -04:00
* Deletes a file .
2015-02-27 11:51:25 -05:00
*
* @ since 4.2 . 0
*
* @ param string $file The path to the file to delete .
*/
function wp_delete_file ( $file ) {
/**
2016-05-22 14:36:27 -04:00
* Filters the path of the file to delete .
2015-02-27 11:51:25 -05:00
*
* @ since 2.1 . 0
*
2016-12-27 04:28:40 -05:00
* @ param string $file Path to the file to delete .
2015-02-27 11:51:25 -05:00
*/
$delete = apply_filters ( 'wp_delete_file' , $file );
if ( ! empty ( $delete ) ) {
@ unlink ( $delete );
}
}
2015-06-16 19:13:26 -04:00
2018-07-05 10:32:25 -04:00
/**
* Deletes a file if its path is within the given directory .
*
* @ since 4.9 . 7
*
* @ param string $file Absolute path to the file to delete .
* @ param string $directory Absolute path to a directory .
* @ return bool True on success , false on failure .
*/
function wp_delete_file_from_directory ( $file , $directory ) {
2019-04-12 16:01:52 -04:00
if ( wp_is_stream ( $file ) ) {
2019-05-17 09:30:02 -04:00
$real_file = $file ;
$real_directory = $directory ;
2019-04-12 16:01:52 -04:00
} else {
$real_file = realpath ( wp_normalize_path ( $file ) );
$real_directory = realpath ( wp_normalize_path ( $directory ) );
}
2018-07-05 10:32:25 -04:00
2019-05-17 09:30:02 -04:00
if ( false !== $real_file ) {
$real_file = wp_normalize_path ( $real_file );
}
if ( false !== $real_directory ) {
$real_directory = wp_normalize_path ( $real_directory );
}
Code Modernization: Replace usage of `strpos()` with `str_starts_with()`.
`str_starts_with()` was introduced in PHP 8.0 to perform a case-sensitive check indicating if the string to search in (haystack) begins with the given substring (needle).
WordPress core includes a polyfill for `str_starts_with()` on PHP < 8.0 as of WordPress 5.9.
This commit replaces `0 === strpos( ... )` with `str_starts_with()` in core files, making the code more readable and consistent, as well as improving performance.
While `strpos()` is slightly faster than the polyfill on PHP < 8.0, `str_starts_with()` is noticeably faster on PHP 8.0+, as it is optimized to avoid unnecessarily searching along the whole haystack if it does not find the needle.
Follow-up to [52039], [52040], [52326].
Props spacedmonkey, costdev, sabernhardt, mukesh27, desrosj, jorbin, TobiasBg, ayeshrajans, lgadzhev, SergeyBiryukov.
Fixes #58012.
Built from https://develop.svn.wordpress.org/trunk@55703
git-svn-id: http://core.svn.wordpress.org/trunk@55215 1a063a9b-81f0-0310-95a4-ce76da25c4cd
2023-05-02 11:45:22 -04:00
if ( false === $real_file || false === $real_directory || ! str_starts_with ( $real_file , trailingslashit ( $real_directory ) ) ) {
2018-07-05 10:32:25 -04:00
return false ;
}
wp_delete_file ( $file );
return true ;
}
2015-06-16 19:13:26 -04:00
/**
* Outputs a small JS snippet on preview tabs / windows to remove `window.name` on unload .
2015-07-13 17:35:24 -04:00
*
2015-06-16 19:13:26 -04:00
* This prevents reusing the same tab for a preview when the user has navigated away .
*
* @ since 4.3 . 0
2017-06-28 08:55:43 -04:00
*
2019-08-04 08:28:56 -04:00
* @ global WP_Post $post Global post object .
2015-06-16 19:13:26 -04:00
*/
function wp_post_preview_js () {
global $post ;
if ( ! is_preview () || empty ( $post ) ) {
return ;
}
2020-01-28 19:45:18 -05:00
// Has to match the window name used in post_submit_meta_box().
2015-06-16 19:13:26 -04:00
$name = 'wp-preview-' . ( int ) $post -> ID ;
?>
< script >
( function () {
var query = document . location . search ;
if ( query && query . indexOf ( 'preview=true' ) !== - 1 ) {
window . name = '<?php echo $name; ?>' ;
}
if ( window . addEventListener ) {
window . addEventListener ( 'unload' , function () { window . name = '' ; }, false );
}
}());
</ script >
< ? php
}
2015-10-05 23:19:25 -04:00
/**
2018-06-27 22:45:29 -04:00
* Parses and formats a MySQL datetime ( Y - m - d H : i : s ) for ISO8601 ( Y - m - d\TH : i : s ) .
2015-10-05 23:19:25 -04:00
*
* Explicitly strips timezones , as datetimes are not saved with any timezone
* information . Including any information on the offset could be misleading .
*
2018-06-27 22:45:29 -04:00
* Despite historical function name , the output does not conform to RFC3339 format ,
* which must contain timezone .
*
2015-10-05 23:19:25 -04:00
* @ since 4.4 . 0
*
* @ param string $date_string Date string to parse and format .
2018-06-27 22:45:29 -04:00
* @ return string Date formatted for ISO8601 without time zone .
2015-10-05 23:19:25 -04:00
*/
function mysql_to_rfc3339 ( $date_string ) {
2018-06-27 22:45:53 -04:00
return mysql2date ( 'Y-m-d\TH:i:s' , $date_string , false );
2015-10-05 23:19:25 -04:00
}
2016-07-06 14:09:32 -04:00
2016-07-08 10:37:30 -04:00
/**
* Attempts to raise the PHP memory limit for memory intensive processes .
*
* Only allows raising the existing limit and prevents lowering it .
*
* @ since 4.6 . 0
*
2016-07-20 12:57:32 -04:00
* @ param string $context Optional . Context in which the function is called . Accepts either 'admin' ,
2023-05-30 14:48:19 -04:00
* 'image' , 'cron' , or an arbitrary other context . If an arbitrary context is passed ,
2020-07-30 15:14:03 -04:00
* the similarly arbitrary { @ see '$context_memory_limit' } filter will be
2016-07-20 12:57:32 -04:00
* invoked . Default 'admin' .
2021-01-04 12:18:04 -05:00
* @ return int | string | false The limit that was set or false on failure .
2016-07-08 10:37:30 -04:00
*/
function wp_raise_memory_limit ( $context = 'admin' ) {
// Exit early if the limit cannot be changed.
if ( false === wp_is_ini_value_changeable ( 'memory_limit' ) ) {
return false ;
}
2019-07-09 01:45:58 -04:00
$current_limit = ini_get ( 'memory_limit' );
2016-07-08 10:37:30 -04:00
$current_limit_int = wp_convert_hr_to_bytes ( $current_limit );
if ( - 1 === $current_limit_int ) {
return false ;
}
$wp_max_limit = WP_MAX_MEMORY_LIMIT ;
$wp_max_limit_int = wp_convert_hr_to_bytes ( $wp_max_limit );
$filtered_limit = $wp_max_limit ;
switch ( $context ) {
case 'admin' :
/**
* Filters the maximum memory limit available for administration screens .
*
2016-07-20 12:57:32 -04:00
* This only applies to administrators , who may require more memory for tasks
* like updates . Memory limits when processing images ( uploaded or edited by
* users of any role ) are handled separately .
2016-07-08 10:37:30 -04:00
*
2016-07-20 12:57:32 -04:00
* The `WP_MAX_MEMORY_LIMIT` constant specifically defines the maximum memory
* limit available when in the administration back end . The default is 256 M
* ( 256 megabytes of memory ) or the original `memory_limit` php . ini value if
* this is higher .
2016-07-08 10:37:30 -04:00
*
* @ since 3.0 . 0
2016-07-20 12:57:32 -04:00
* @ since 4.6 . 0 The default now takes the original `memory_limit` into account .
2016-07-08 10:37:30 -04:00
*
2016-07-20 12:57:32 -04:00
* @ param int | string $filtered_limit The maximum WordPress memory limit . Accepts an integer
* ( bytes ), or a shorthand string notation , such as '256M' .
2016-07-08 10:37:30 -04:00
*/
$filtered_limit = apply_filters ( 'admin_memory_limit' , $filtered_limit );
break ;
case 'image' :
/**
* Filters the memory limit allocated for image manipulation .
*
* @ since 3.5 . 0
2016-07-20 12:57:32 -04:00
* @ since 4.6 . 0 The default now takes the original `memory_limit` into account .
2016-07-08 10:37:30 -04:00
*
2023-05-30 13:45:21 -04:00
* @ param int | string $filtered_limit Maximum memory limit to allocate for image processing .
2016-07-20 12:57:32 -04:00
* Default `WP_MAX_MEMORY_LIMIT` or the original
* php . ini `memory_limit` , whichever is higher .
2016-07-08 10:37:30 -04:00
* Accepts an integer ( bytes ), or a shorthand string
* notation , such as '256M' .
*/
$filtered_limit = apply_filters ( 'image_memory_limit' , $filtered_limit );
break ;
2023-05-30 14:48:19 -04:00
case 'cron' :
/**
* Filters the memory limit allocated for WP - Cron event processing .
*
* @ since 6.3 . 0
*
* @ param int | string $filtered_limit Maximum memory limit to allocate for WP - Cron .
* Default `WP_MAX_MEMORY_LIMIT` or the original
* php . ini `memory_limit` , whichever is higher .
* Accepts an integer ( bytes ), or a shorthand string
* notation , such as '256M' .
*/
$filtered_limit = apply_filters ( 'cron_memory_limit' , $filtered_limit );
break ;
2016-07-08 10:37:30 -04:00
default :
/**
2023-05-30 13:45:21 -04:00
* Filters the memory limit allocated for an arbitrary context .
2016-07-08 10:37:30 -04:00
*
* The dynamic portion of the hook name , `$context` , refers to an arbitrary
* context passed on calling the function . This allows for plugins to define
* their own contexts for raising the memory limit .
*
* @ since 4.6 . 0
*
2023-05-30 13:45:21 -04:00
* @ param int | string $filtered_limit Maximum memory limit to allocate for this context .
* Default WP_MAX_MEMORY_LIMIT ` or the original php.ini ` memory_limit ` ,
2016-07-20 12:57:32 -04:00
* whichever is higher . Accepts an integer ( bytes ), or a
* shorthand string notation , such as '256M' .
2016-07-08 10:37:30 -04:00
*/
$filtered_limit = apply_filters ( " { $context } _memory_limit " , $filtered_limit );
break ;
}
$filtered_limit_int = wp_convert_hr_to_bytes ( $filtered_limit );
if ( - 1 === $filtered_limit_int || ( $filtered_limit_int > $wp_max_limit_int && $filtered_limit_int > $current_limit_int ) ) {
2019-07-09 01:45:58 -04:00
if ( false !== ini_set ( 'memory_limit' , $filtered_limit ) ) {
2016-07-08 10:37:30 -04:00
return $filtered_limit ;
} else {
return false ;
}
} elseif ( - 1 === $wp_max_limit_int || $wp_max_limit_int > $current_limit_int ) {
2019-07-09 01:45:58 -04:00
if ( false !== ini_set ( 'memory_limit' , $wp_max_limit ) ) {
2016-07-08 10:37:30 -04:00
return $wp_max_limit ;
} else {
return false ;
}
}
return false ;
}
Customize: Implement customized state persistence with changesets.
Includes infrastructure developed in the Customize Snapshots feature plugin.
See https://make.wordpress.org/core/2016/10/12/customize-changesets-technical-design-decisions/
Props westonruter, valendesigns, utkarshpatel, stubgo, lgedeon, ocean90, ryankienstra, mihai2u, dlh, aaroncampbell, jonathanbardo, jorbin.
See #28721.
See #31089.
Fixes #30937.
Fixes #31517.
Fixes #30028.
Fixes #23225.
Fixes #34142.
Fixes #36485.
Built from https://develop.svn.wordpress.org/trunk@38810
git-svn-id: http://core.svn.wordpress.org/trunk@38753 1a063a9b-81f0-0310-95a4-ce76da25c4cd
2016-10-18 16:05:31 -04:00
/**
2022-08-12 05:53:11 -04:00
* Generates a random UUID ( version 4 ) .
Customize: Implement customized state persistence with changesets.
Includes infrastructure developed in the Customize Snapshots feature plugin.
See https://make.wordpress.org/core/2016/10/12/customize-changesets-technical-design-decisions/
Props westonruter, valendesigns, utkarshpatel, stubgo, lgedeon, ocean90, ryankienstra, mihai2u, dlh, aaroncampbell, jonathanbardo, jorbin.
See #28721.
See #31089.
Fixes #30937.
Fixes #31517.
Fixes #30028.
Fixes #23225.
Fixes #34142.
Fixes #36485.
Built from https://develop.svn.wordpress.org/trunk@38810
git-svn-id: http://core.svn.wordpress.org/trunk@38753 1a063a9b-81f0-0310-95a4-ce76da25c4cd
2016-10-18 16:05:31 -04:00
*
* @ since 4.7 . 0
*
* @ return string UUID .
*/
function wp_generate_uuid4 () {
2017-11-30 18:11:00 -05:00
return sprintf (
'%04x%04x-%04x-%04x-%04x-%04x%04x%04x' ,
2018-08-16 21:51:36 -04:00
mt_rand ( 0 , 0xffff ),
mt_rand ( 0 , 0xffff ),
Customize: Implement customized state persistence with changesets.
Includes infrastructure developed in the Customize Snapshots feature plugin.
See https://make.wordpress.org/core/2016/10/12/customize-changesets-technical-design-decisions/
Props westonruter, valendesigns, utkarshpatel, stubgo, lgedeon, ocean90, ryankienstra, mihai2u, dlh, aaroncampbell, jonathanbardo, jorbin.
See #28721.
See #31089.
Fixes #30937.
Fixes #31517.
Fixes #30028.
Fixes #23225.
Fixes #34142.
Fixes #36485.
Built from https://develop.svn.wordpress.org/trunk@38810
git-svn-id: http://core.svn.wordpress.org/trunk@38753 1a063a9b-81f0-0310-95a4-ce76da25c4cd
2016-10-18 16:05:31 -04:00
mt_rand ( 0 , 0xffff ),
mt_rand ( 0 , 0x0fff ) | 0x4000 ,
mt_rand ( 0 , 0x3fff ) | 0x8000 ,
2018-08-16 21:51:36 -04:00
mt_rand ( 0 , 0xffff ),
mt_rand ( 0 , 0xffff ),
mt_rand ( 0 , 0xffff )
Customize: Implement customized state persistence with changesets.
Includes infrastructure developed in the Customize Snapshots feature plugin.
See https://make.wordpress.org/core/2016/10/12/customize-changesets-technical-design-decisions/
Props westonruter, valendesigns, utkarshpatel, stubgo, lgedeon, ocean90, ryankienstra, mihai2u, dlh, aaroncampbell, jonathanbardo, jorbin.
See #28721.
See #31089.
Fixes #30937.
Fixes #31517.
Fixes #30028.
Fixes #23225.
Fixes #34142.
Fixes #36485.
Built from https://develop.svn.wordpress.org/trunk@38810
git-svn-id: http://core.svn.wordpress.org/trunk@38753 1a063a9b-81f0-0310-95a4-ce76da25c4cd
2016-10-18 16:05:31 -04:00
);
}
2016-10-20 22:54:34 -04:00
2017-09-18 19:04:44 -04:00
/**
* Validates that a UUID is valid .
*
* @ since 4.9 . 0
*
* @ param mixed $uuid UUID to check .
2018-09-24 16:46:26 -04:00
* @ param int $version Specify which version of UUID to check against . Default is none ,
* to accept any UUID version . Otherwise , only version allowed is `4` .
2017-09-18 19:04:44 -04:00
* @ return bool The string is a valid UUID or false on failure .
*/
function wp_is_uuid ( $uuid , $version = null ) {
if ( ! is_string ( $uuid ) ) {
return false ;
}
if ( is_numeric ( $version ) ) {
if ( 4 !== ( int ) $version ) {
_doing_it_wrong ( __FUNCTION__ , __ ( 'Only UUID V4 is supported at this time.' ), '4.9.0' );
return false ;
}
$regex = '/^[0-9a-f]{8}-[0-9a-f]{4}-4[0-9a-f]{3}-[89ab][0-9a-f]{3}-[0-9a-f]{12}$/' ;
} else {
$regex = '/^[0-9a-f]{8}-[0-9a-f]{4}-[0-9a-f]{4}-[0-9a-f]{4}-[0-9a-f]{12}$/' ;
}
return ( bool ) preg_match ( $regex , $uuid );
}
2018-09-24 16:57:23 -04:00
/**
2020-06-20 08:02:12 -04:00
* Gets unique ID .
2018-09-24 16:57:23 -04:00
*
* This is a PHP implementation of Underscore ' s uniqueId method . A static variable
* contains an integer that is incremented with each call . This number is returned
* with the optional prefix . As such the returned value is not universally unique ,
* but it is unique across the life of the PHP process .
*
2019-01-06 14:52:51 -05:00
* @ since 5.0 . 3
2018-09-24 16:57:23 -04:00
*
* @ param string $prefix Prefix for the returned ID .
* @ return string Unique ID .
*/
function wp_unique_id ( $prefix = '' ) {
static $id_counter = 0 ;
return $prefix . ( string ) ++ $id_counter ;
}
2016-10-20 22:54:34 -04:00
/**
2020-06-20 08:02:12 -04:00
* Gets last changed date for the specified cache group .
2016-10-20 22:54:34 -04:00
*
* @ since 4.7 . 0
*
2017-01-13 09:16:44 -05:00
* @ param string $group Where the cache contents are grouped .
2020-06-19 18:55:12 -04:00
* @ return string UNIX timestamp with microseconds representing when the group was last changed .
2016-10-20 22:54:34 -04:00
*/
function wp_cache_get_last_changed ( $group ) {
$last_changed = wp_cache_get ( 'last_changed' , $group );
2023-05-02 07:26:24 -04:00
if ( $last_changed ) {
return $last_changed ;
2016-10-20 22:54:34 -04:00
}
2023-05-02 07:26:24 -04:00
return wp_cache_set_last_changed ( $group );
}
/**
* Sets last changed date for the specified cache group to now .
*
* @ since 6.3 . 0
*
* @ param string $group Where the cache contents are grouped .
* @ return string UNIX timestamp when the group was last changed .
*/
function wp_cache_set_last_changed ( $group ) {
$previous_time = wp_cache_get ( 'last_changed' , $group );
$time = microtime ();
wp_cache_set ( 'last_changed' , $time , $group );
/**
* Fires after a cache group `last_changed` time is updated .
* This may occur multiple times per page load and registered
* actions must be performant .
*
* @ since 6.3 . 0
*
* @ param string $group The cache group name .
* @ param int $time The new last changed time .
* @ param int | false $previous_time The previous last changed time . False if not previously set .
*/
do_action ( 'wp_cache_set_last_changed' , $group , $time , $previous_time );
return $time ;
2016-10-25 17:26:32 -04:00
}
2017-07-26 22:24:42 -04:00
/**
2022-08-12 05:53:11 -04:00
* Sends an email to the old site admin email address when the site admin email address changes .
2017-07-26 22:24:42 -04:00
*
* @ since 4.9 . 0
*
* @ param string $old_email The old site admin email address .
* @ param string $new_email The new site admin email address .
* @ param string $option_name The relevant database option name .
*/
function wp_site_admin_email_change_notification ( $old_email , $new_email , $option_name ) {
2018-01-23 08:45:32 -05:00
$send = true ;
// Don't send the notification to the default 'admin_email' value.
if ( 'you@example.com' === $old_email ) {
$send = false ;
}
2017-07-26 22:24:42 -04:00
/**
* Filters whether to send the site admin email change notification email .
*
* @ since 4.9 . 0
*
* @ param bool $send Whether to send the email notification .
* @ param string $old_email The old site admin email address .
* @ param string $new_email The new site admin email address .
*/
2018-01-23 08:45:32 -05:00
$send = apply_filters ( 'send_site_admin_email_change_email' , $send , $old_email , $new_email );
2017-07-26 22:24:42 -04:00
if ( ! $send ) {
return ;
}
/* translators: Do not translate OLD_EMAIL, NEW_EMAIL, SITENAME, SITEURL: those are placeholders. */
2017-11-30 18:11:00 -05:00
$email_change_text = __ (
' Hi ,
2017-07-26 22:24:42 -04:00
This notice confirms that the admin email address was changed on ###SITENAME###.
The new admin email address is ###NEW_EMAIL###.
This email has been sent to ###OLD_EMAIL###
Regards ,
All at ###SITENAME###
2017-11-30 18:11:00 -05:00
###SITEURL###'
);
2017-07-26 22:24:42 -04:00
$email_change_email = array (
'to' => $old_email ,
2019-09-02 20:41:05 -04:00
/* translators: Site admin email change notification email subject. %s: Site title. */
2019-04-08 02:17:51 -04:00
'subject' => __ ( '[%s] Admin Email Changed' ),
2017-07-26 22:24:42 -04:00
'message' => $email_change_text ,
'headers' => '' ,
);
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 13:13:59 -04:00
2020-01-28 19:45:18 -05:00
// Get site name.
2017-07-26 22:24:42 -04:00
$site_name = wp_specialchars_decode ( get_option ( 'blogname' ), ENT_QUOTES );
/**
* Filters the contents of the email notification sent when the site admin email address is changed .
*
* @ since 4.9 . 0
*
* @ param array $email_change_email {
2020-09-21 12:46:06 -04:00
* Used to build wp_mail () .
2017-07-26 22:24:42 -04:00
*
2020-09-21 12:46:06 -04:00
* @ type string $to The intended recipient .
* @ type string $subject The subject of the email .
* @ type string $message The content of the email .
* The following strings have a special meaning and will get replaced dynamically :
* - ###OLD_EMAIL### The old site admin email address.
* - ###NEW_EMAIL### The new site admin email address.
* - ###SITENAME### The name of the site.
* - ###SITEURL### The URL to the site.
* @ type string $headers Headers .
* }
2017-07-26 22:24:42 -04:00
* @ param string $old_email The old site admin email address .
* @ param string $new_email The new site admin email address .
*/
$email_change_email = apply_filters ( 'site_admin_email_change_email' , $email_change_email , $old_email , $new_email );
$email_change_email [ 'message' ] = str_replace ( '###OLD_EMAIL###' , $old_email , $email_change_email [ 'message' ] );
$email_change_email [ 'message' ] = str_replace ( '###NEW_EMAIL###' , $new_email , $email_change_email [ 'message' ] );
2017-11-30 18:11:00 -05:00
$email_change_email [ 'message' ] = str_replace ( '###SITENAME###' , $site_name , $email_change_email [ 'message' ] );
$email_change_email [ 'message' ] = str_replace ( '###SITEURL###' , home_url (), $email_change_email [ 'message' ] );
wp_mail (
2018-08-16 21:51:36 -04:00
$email_change_email [ 'to' ],
sprintf (
2017-11-30 18:11:00 -05:00
$email_change_email [ 'subject' ],
$site_name
2018-08-16 21:51:36 -04:00
),
$email_change_email [ 'message' ],
$email_change_email [ 'headers' ]
2017-11-30 18:11:00 -05:00
);
2017-07-26 22:24:42 -04:00
}
2018-04-12 17:20:23 -04:00
/**
2022-08-12 05:53:11 -04:00
* Returns an anonymized IPv4 or IPv6 address .
2018-04-12 17:20:23 -04:00
*
2018-05-01 20:41:21 -04:00
* @ since 4.9 . 6 Abstracted from `WP_Community_Events::get_unsafe_client_ip()` .
2018-04-12 17:20:23 -04:00
*
2020-06-20 08:58:10 -04:00
* @ param string $ip_addr The IPv4 or IPv6 address to be anonymized .
* @ param bool $ipv6_fallback Optional . Whether to return the original IPv6 address if the needed functions
* to anonymize it are not present . Default false , return `::` ( unspecified address ) .
2018-04-12 17:20:23 -04:00
* @ return string The anonymized IP address .
*/
function wp_privacy_anonymize_ip ( $ip_addr , $ipv6_fallback = false ) {
2021-09-09 18:56:56 -04:00
if ( empty ( $ip_addr ) ) {
return '0.0.0.0' ;
}
2018-04-12 17:20:23 -04:00
// Detect what kind of IP address this is.
$ip_prefix = '' ;
$is_ipv6 = substr_count ( $ip_addr , ':' ) > 1 ;
$is_ipv4 = ( 3 === substr_count ( $ip_addr , '.' ) );
if ( $is_ipv6 && $is_ipv4 ) {
// IPv6 compatibility mode, temporarily strip the IPv6 part, and treat it like IPv4.
$ip_prefix = '::ffff:' ;
$ip_addr = preg_replace ( '/^\[?[0-9a-f:]*:/i' , '' , $ip_addr );
$ip_addr = str_replace ( ']' , '' , $ip_addr );
$is_ipv6 = false ;
}
if ( $is_ipv6 ) {
// IPv6 addresses will always be enclosed in [] if there's a port.
$left_bracket = strpos ( $ip_addr , '[' );
$right_bracket = strpos ( $ip_addr , ']' );
$percent = strpos ( $ip_addr , '%' );
$netmask = 'ffff:ffff:ffff:ffff:0000:0000:0000:0000' ;
// Strip the port (and [] from IPv6 addresses), if they exist.
if ( false !== $left_bracket && false !== $right_bracket ) {
$ip_addr = substr ( $ip_addr , $left_bracket + 1 , $right_bracket - $left_bracket - 1 );
} elseif ( false !== $left_bracket || false !== $right_bracket ) {
// The IP has one bracket, but not both, so it's malformed.
return '::' ;
}
// Strip the reachability scope.
if ( false !== $percent ) {
$ip_addr = substr ( $ip_addr , 0 , $percent );
}
// No invalid characters should be left.
if ( preg_match ( '/[^0-9a-f:]/i' , $ip_addr ) ) {
return '::' ;
}
// Partially anonymize the IP by reducing it to the corresponding network ID.
if ( function_exists ( 'inet_pton' ) && function_exists ( 'inet_ntop' ) ) {
$ip_addr = inet_ntop ( inet_pton ( $ip_addr ) & inet_pton ( $netmask ) );
2018-08-16 21:51:36 -04:00
if ( false === $ip_addr ) {
2018-04-12 17:20:23 -04:00
return '::' ;
}
} elseif ( ! $ipv6_fallback ) {
return '::' ;
}
} elseif ( $is_ipv4 ) {
// Strip any port and partially anonymize the IP.
$last_octet_position = strrpos ( $ip_addr , '.' );
$ip_addr = substr ( $ip_addr , 0 , $last_octet_position ) . '.0' ;
} else {
return '0.0.0.0' ;
}
// Restore the IPv6 prefix to compatibility mode addresses.
return $ip_prefix . $ip_addr ;
}
/**
2022-08-12 05:53:11 -04:00
* Returns uniform " anonymous " data by type .
2018-04-12 17:20:23 -04:00
*
2018-05-01 20:41:21 -04:00
* @ since 4.9 . 6
2018-04-12 17:20:23 -04:00
*
2020-06-20 08:58:10 -04:00
* @ param string $type The type of data to be anonymized .
2023-02-21 11:39:19 -05:00
* @ param string $data Optional . The data to be anonymized . Default empty string .
2018-04-12 17:20:23 -04:00
* @ return string The anonymous data for the requested type .
*/
function wp_privacy_anonymize_data ( $type , $data = '' ) {
switch ( $type ) {
case 'email' :
$anonymous = 'deleted@site.invalid' ;
break ;
case 'url' :
$anonymous = 'https://site.invalid' ;
break ;
case 'ip' :
$anonymous = wp_privacy_anonymize_ip ( $data );
break ;
case 'date' :
$anonymous = '0000-00-00 00:00:00' ;
break ;
case 'text' :
2019-09-02 20:41:05 -04:00
/* translators: Deleted text. */
2018-04-12 17:20:23 -04:00
$anonymous = __ ( '[deleted]' );
break ;
case 'longtext' :
2019-09-02 20:41:05 -04:00
/* translators: Deleted long text. */
2018-04-12 17:20:23 -04:00
$anonymous = __ ( 'This content was deleted by the author.' );
break ;
default :
$anonymous = '' ;
2019-08-22 10:50:55 -04:00
break ;
2018-04-12 17:20:23 -04:00
}
/**
* Filters the anonymous data for each type .
*
2018-05-01 20:41:21 -04:00
* @ since 4.9 . 6
2018-04-12 17:20:23 -04:00
*
* @ param string $anonymous Anonymized data .
* @ param string $type Type of the data .
* @ param string $data Original data .
*/
return apply_filters ( 'wp_privacy_anonymize_data' , $anonymous , $type , $data );
}
2018-04-16 04:53:20 -04:00
Privacy: Rename exports folder to avoid deleting other files.
Previously, personal data exports were stored in `wp-content/uploads/exports`, which is generic enough that it's likely there are existing folders with that name, either created by plugins or manually by administrators. If that folder were reused by Core, then `wp_privacy_delete_old_export_files()` would delete all of the existing files inside it, which is almost certainly not what the site owner wants or expects.
To avoid that, the folder is being renamed to include a specific reference to Core, and a more verbose description of its purpose. With those factored in, it's very unlikely that there will be any conflicts with existing folders.
The `wp_privacy_exports_dir()` and `wp_privacy_exports_url()` functions were introduced to provide a canonical source for the location, and the `wp_privacy_exports_dir` and `wp_privacy_exports_url` filters were introduced to allow plugins to customize it.
Props johnjamesjacoby, allendav.
Fixes #44091.
Built from https://develop.svn.wordpress.org/trunk@43284
git-svn-id: http://core.svn.wordpress.org/trunk@43113 1a063a9b-81f0-0310-95a4-ce76da25c4cd
2018-05-15 16:22:20 -04:00
/**
* Returns the directory used to store personal data export files .
*
* @ since 4.9 . 6
*
* @ see wp_privacy_exports_url
*
* @ return string Exports directory .
*/
function wp_privacy_exports_dir () {
$upload_dir = wp_upload_dir ();
$exports_dir = trailingslashit ( $upload_dir [ 'basedir' ] ) . 'wp-personal-data-exports/' ;
/**
* Filters the directory used to store personal data export files .
*
* @ since 4.9 . 6
2020-09-24 01:00:06 -04:00
* @ since 5.5 . 0 Exports now use relative paths , so changes to the directory
* via this filter should be reflected on the server .
Privacy: Rename exports folder to avoid deleting other files.
Previously, personal data exports were stored in `wp-content/uploads/exports`, which is generic enough that it's likely there are existing folders with that name, either created by plugins or manually by administrators. If that folder were reused by Core, then `wp_privacy_delete_old_export_files()` would delete all of the existing files inside it, which is almost certainly not what the site owner wants or expects.
To avoid that, the folder is being renamed to include a specific reference to Core, and a more verbose description of its purpose. With those factored in, it's very unlikely that there will be any conflicts with existing folders.
The `wp_privacy_exports_dir()` and `wp_privacy_exports_url()` functions were introduced to provide a canonical source for the location, and the `wp_privacy_exports_dir` and `wp_privacy_exports_url` filters were introduced to allow plugins to customize it.
Props johnjamesjacoby, allendav.
Fixes #44091.
Built from https://develop.svn.wordpress.org/trunk@43284
git-svn-id: http://core.svn.wordpress.org/trunk@43113 1a063a9b-81f0-0310-95a4-ce76da25c4cd
2018-05-15 16:22:20 -04:00
*
* @ param string $exports_dir Exports directory .
*/
return apply_filters ( 'wp_privacy_exports_dir' , $exports_dir );
}
/**
* Returns the URL of the directory used to store personal data export files .
*
* @ since 4.9 . 6
*
* @ see wp_privacy_exports_dir
*
* @ return string Exports directory URL .
*/
function wp_privacy_exports_url () {
$upload_dir = wp_upload_dir ();
$exports_url = trailingslashit ( $upload_dir [ 'baseurl' ] ) . 'wp-personal-data-exports/' ;
/**
* Filters the URL of the directory used to store personal data export files .
*
* @ since 4.9 . 6
2020-09-24 01:00:06 -04:00
* @ since 5.5 . 0 Exports now use relative paths , so changes to the directory URL
* via this filter should be reflected on the server .
Privacy: Rename exports folder to avoid deleting other files.
Previously, personal data exports were stored in `wp-content/uploads/exports`, which is generic enough that it's likely there are existing folders with that name, either created by plugins or manually by administrators. If that folder were reused by Core, then `wp_privacy_delete_old_export_files()` would delete all of the existing files inside it, which is almost certainly not what the site owner wants or expects.
To avoid that, the folder is being renamed to include a specific reference to Core, and a more verbose description of its purpose. With those factored in, it's very unlikely that there will be any conflicts with existing folders.
The `wp_privacy_exports_dir()` and `wp_privacy_exports_url()` functions were introduced to provide a canonical source for the location, and the `wp_privacy_exports_dir` and `wp_privacy_exports_url` filters were introduced to allow plugins to customize it.
Props johnjamesjacoby, allendav.
Fixes #44091.
Built from https://develop.svn.wordpress.org/trunk@43284
git-svn-id: http://core.svn.wordpress.org/trunk@43113 1a063a9b-81f0-0310-95a4-ce76da25c4cd
2018-05-15 16:22:20 -04:00
*
* @ param string $exports_url Exports directory URL .
*/
return apply_filters ( 'wp_privacy_exports_url' , $exports_url );
}
2018-04-30 16:09:23 -04:00
/**
2022-08-12 05:53:11 -04:00
* Schedules a `WP_Cron` job to delete expired export files .
2018-04-30 16:09:23 -04:00
*
* @ since 4.9 . 6
*/
function wp_schedule_delete_old_privacy_export_files () {
2018-05-03 17:11:21 -04:00
if ( wp_installing () ) {
return ;
}
2018-04-30 16:09:23 -04:00
if ( ! wp_next_scheduled ( 'wp_privacy_delete_old_export_files' ) ) {
wp_schedule_event ( time (), 'hourly' , 'wp_privacy_delete_old_export_files' );
}
}
/**
* Cleans up export files older than three days old .
*
* The export files are stored in `wp-content/uploads` , and are therefore publicly
* accessible . A CSPRN is appended to the filename to mitigate the risk of an
* unauthorized person downloading the file , but it is still possible . Deleting
* the file after the data subject has had a chance to delete it adds an additional
* layer of protection .
*
* @ since 4.9 . 6
*/
function wp_privacy_delete_old_export_files () {
2019-03-15 15:00:51 -04:00
$exports_dir = wp_privacy_exports_dir ();
if ( ! is_dir ( $exports_dir ) ) {
return ;
}
2018-05-01 13:43:22 -04:00
2020-02-06 01:33:11 -05:00
require_once ABSPATH . 'wp-admin/includes/file.php' ;
2021-01-27 18:46:58 -05:00
$export_files = list_files ( $exports_dir , 100 , array ( 'index.php' ) );
2018-04-30 16:09:23 -04:00
/**
* Filters the lifetime , in seconds , of a personal data export file .
*
* By default , the lifetime is 3 days . Once the file reaches that age , it will automatically
* be deleted by a cron job .
*
* @ since 4.9 . 6
*
* @ param int $expiration The expiration age of the export , in seconds .
*/
$expiration = apply_filters ( 'wp_privacy_export_expiration' , 3 * DAY_IN_SECONDS );
foreach ( ( array ) $export_files as $export_file ) {
$file_age_in_seconds = time () - filemtime ( $export_file );
if ( $expiration < $file_age_in_seconds ) {
unlink ( $export_file );
}
}
}
General: Make Update PHP notice link customizable.
After [42832], [42891] and [43006], this changeset refines the core notice informing about an outdated PHP version:
* The link to the Update PHP information page can now be adjusted using either a `WP_UPDATE_PHP_URL` environment variable, or a new `wp_update_php_url` filter.
* If that URL is different from the default one that points to https://wordpress.org/support/update-php/ or its localized equivalent, a note indicates that the linked resource has not been provided by WordPress itself, and the default URL is still linked to as an additional resource.
* The URL for the default information page has been updated to use the slug `update-php` instead of `upgrade-php`.
* `@since` annotations have been updated.
Going forward, admin areas that display information related to the PHP version should use the new function `wp_get_update_php_url()`.
Props afragen, fierevere, flixos90, markjaquith, miss_jwo, nerrad, pento, schlessera, SergeyBiryukov, spacedmonkey.
Fixes #45686. See #41191.
Built from https://develop.svn.wordpress.org/trunk@44476
git-svn-id: http://core.svn.wordpress.org/trunk@44307 1a063a9b-81f0-0310-95a4-ce76da25c4cd
2019-01-08 12:27:50 -05:00
/**
* Gets the URL to learn more about updating the PHP version the site is running on .
*
* This URL can be overridden by specifying an environment variable `WP_UPDATE_PHP_URL` or by using the
* { @ see 'wp_update_php_url' } filter . Providing an empty string is not allowed and will result in the
* default URL being used . Furthermore the page the URL links to should preferably be localized in the
* site language .
*
* @ since 5.1 . 0
*
* @ return string URL to learn more about updating PHP .
*/
function wp_get_update_php_url () {
$default_url = wp_get_default_update_php_url ();
$update_url = $default_url ;
if ( false !== getenv ( 'WP_UPDATE_PHP_URL' ) ) {
$update_url = getenv ( 'WP_UPDATE_PHP_URL' );
}
/**
* Filters the URL to learn more about updating the PHP version the site is running on .
*
* Providing an empty string is not allowed and will result in the default URL being used . Furthermore
* the page the URL links to should preferably be localized in the site language .
*
* @ since 5.1 . 0
*
* @ param string $update_url URL to learn more about updating PHP .
*/
$update_url = apply_filters ( 'wp_update_php_url' , $update_url );
if ( empty ( $update_url ) ) {
$update_url = $default_url ;
}
return $update_url ;
}
/**
* Gets the default URL to learn more about updating the PHP version the site is running on .
*
* Do not use this function to retrieve this URL . Instead , use { @ see wp_get_update_php_url ()} when relying on the URL .
* This function does not allow modifying the returned URL , and is only used to compare the actually used URL with the
* default one .
*
* @ since 5.1 . 0
* @ access private
*
* @ return string Default URL to learn more about updating PHP .
*/
function wp_get_default_update_php_url () {
return _x ( 'https://wordpress.org/support/update-php/' , 'localized PHP upgrade information page' );
}
2019-01-16 12:07:00 -05:00
/**
* Prints the default annotation for the web host altering the " Update PHP " page URL .
*
* This function is to be used after { @ see wp_get_update_php_url ()} to display a consistent
* annotation if the web host has altered the default " Update PHP " page URL .
*
* @ since 5.1 . 0
2019-03-19 12:54:52 -04:00
* @ since 5.2 . 0 Added the `$before` and `$after` parameters .
*
* @ param string $before Markup to output before the annotation . Default `<p class="description">` .
* @ param string $after Markup to output after the annotation . Default `</p>` .
2019-01-16 12:07:00 -05:00
*/
2019-03-19 12:54:52 -04:00
function wp_update_php_annotation ( $before = '<p class="description">' , $after = '</p>' ) {
$annotation = wp_get_update_php_annotation ();
2019-03-27 18:37:51 -04:00
if ( $annotation ) {
echo $before . $annotation . $after ;
}
2019-03-19 12:54:52 -04:00
}
/**
* Returns the default annotation for the web hosting altering the " Update PHP " page URL .
*
* This function is to be used after { @ see wp_get_update_php_url ()} to return a consistent
* annotation if the web host has altered the default " Update PHP " page URL .
*
* @ since 5.2 . 0
*
2020-06-19 18:55:12 -04:00
* @ return string Update PHP page annotation . An empty string if no custom URLs are provided .
2019-03-19 12:54:52 -04:00
*/
function wp_get_update_php_annotation () {
2019-01-16 12:07:00 -05:00
$update_url = wp_get_update_php_url ();
$default_url = wp_get_default_update_php_url ();
if ( $update_url === $default_url ) {
2019-03-19 12:54:52 -04:00
return '' ;
2019-01-16 12:07:00 -05:00
}
2019-03-19 12:54:52 -04:00
$annotation = sprintf (
2019-09-02 20:41:05 -04:00
/* translators: %s: Default Update PHP page URL. */
2019-01-16 12:07:00 -05:00
__ ( 'This resource is provided by your web host, and is specific to your site. For more information, <a href="%s" target="_blank">see the official WordPress documentation</a>.' ),
esc_url ( $default_url )
);
2019-03-19 12:54:52 -04:00
return $annotation ;
2019-01-16 12:07:00 -05:00
}
2019-03-07 16:32:50 -05:00
/**
* Gets the URL for directly updating the PHP version the site is running on .
*
* A URL will only be returned if the `WP_DIRECT_UPDATE_PHP_URL` environment variable is specified or
* by using the { @ see 'wp_direct_php_update_url' } filter . This allows hosts to send users directly to
* the page where they can update PHP to a newer version .
*
2019-03-11 08:59:50 -04:00
* @ since 5.1 . 1
*
2019-03-07 16:32:50 -05:00
* @ return string URL for directly updating PHP or empty string .
*/
function wp_get_direct_php_update_url () {
$direct_update_url = '' ;
if ( false !== getenv ( 'WP_DIRECT_UPDATE_PHP_URL' ) ) {
$direct_update_url = getenv ( 'WP_DIRECT_UPDATE_PHP_URL' );
}
/**
* Filters the URL for directly updating the PHP version the site is running on from the host .
*
* @ since 5.1 . 1
*
* @ param string $direct_update_url URL for directly updating PHP .
*/
$direct_update_url = apply_filters ( 'wp_direct_php_update_url' , $direct_update_url );
return $direct_update_url ;
}
/**
2022-08-12 05:53:11 -04:00
* Displays a button directly linking to a PHP update process .
2019-03-07 16:32:50 -05:00
*
* This provides hosts with a way for users to be sent directly to their PHP update process .
*
* The button is only displayed if a URL is returned by `wp_get_direct_php_update_url()` .
*
* @ since 5.1 . 1
*/
function wp_direct_php_update_button () {
$direct_update_url = wp_get_direct_php_update_url ();
if ( empty ( $direct_update_url ) ) {
return ;
}
echo '<p class="button-container">' ;
printf (
2020-10-19 19:39:04 -04:00
'<a class="button button-primary" href="%1$s" target="_blank" rel="noopener">%2$s <span class="screen-reader-text">%3$s</span><span aria-hidden="true" class="dashicons dashicons-external"></span></a>' ,
2019-03-07 16:32:50 -05:00
esc_url ( $direct_update_url ),
__ ( 'Update PHP' ),
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 12:10:21 -05:00
/* translators: Hidden accessibility text. */
2019-03-07 16:32:50 -05:00
__ ( '(opens in a new tab)' )
);
echo '</p>' ;
}
2019-04-02 19:33:53 -04:00
Security, Site Health: Make migrating a site to HTTPS a one-click interaction.
Switching a WordPress site from HTTP to HTTPS has historically been a tedious task. While on the surface the Site Address and WordPress Address have to be updated, existing content still remains using HTTP URLs where hard-coded in the database. Furthermore, updating _two_ URLs to migrate to HTTPS is still a fairly unintuitive step which is not clearly explained.
This changeset simplifies migration from HTTP to HTTPS and, where possible, makes it a one-click interaction.
* Automatically replace insecure versions of the Site Address (`home_url()`) with its HTTPS counterpart on the fly if the site has been migrated from HTTP to HTTPS. This is accomplished by introducing a `https_migration_required` option and enabling it when the `home_url()` is accordingly changed.
* A new `wp_replace_insecure_home_url()` function is hooked into various pieces of content to replace URLs accordingly.
* The migration only kicks in when the Site Address (`home_url()`) and WordPress Address (`site_url()`) match, which is the widely common case. Configurations where these differ are often maintained by more advanced users, where this migration routine would be less essential - something to potentially iterate on in the future though.
* The migration does not actually update content in the database. More savvy users that prefer to do that can prevent the migration logic from running by either deleting the `https_migration_required` option or using the new `wp_should_replace_insecure_home_url` filter.
* For fresh sites that do not have any content yet at the point of changing the URLs to HTTPS, the migration will also be skipped since it would not be relevant.
* Expose a primary action in the Site Health recommendation, if HTTPS is already supported by the environment, built on top of the HTTPS detection mechanism from [49904]. When clicked, the default behavior is to update `home_url()` and `site_url()` in one go to their HTTPS counterpart.
* A new `wp_update_urls_to_https()` function takes care of the update routine.
* A new `update_https` meta capability is introduced to control access.
* If the site's URLs are controlled by constants, this update is not automatically possible, so in these scenarios the user is informed about that in the HTTPS status check in Site Health.
* Allow hosting providers to modify the URLs linked to in the HTTPS status check in Site Health, similar to how that is possible for the URLs around updating the PHP version.
* A `WP_UPDATE_HTTPS_URL` environment variable or `wp_update_https_url` filter can be used to provide a custom URL with guidance about updating the site to use HTTPS.
* A `WP_DIRECT_UPDATE_HTTPS_URL` environment variable or `wp_direct_update_https_url` filter can be used to provide a custom URL for the primary CTA to update the site to use HTTPS.
Props flixos90, timothyblynjacobs.
Fixes #51437.
Built from https://develop.svn.wordpress.org/trunk@50131
git-svn-id: http://core.svn.wordpress.org/trunk@49810 1a063a9b-81f0-0310-95a4-ce76da25c4cd
2021-02-01 19:10:01 -05:00
/**
* Gets the URL to learn more about updating the site to use HTTPS .
*
* This URL can be overridden by specifying an environment variable `WP_UPDATE_HTTPS_URL` or by using the
* { @ see 'wp_update_https_url' } filter . Providing an empty string is not allowed and will result in the
* default URL being used . Furthermore the page the URL links to should preferably be localized in the
* site language .
*
* @ since 5.7 . 0
*
* @ return string URL to learn more about updating to HTTPS .
*/
function wp_get_update_https_url () {
$default_url = wp_get_default_update_https_url ();
$update_url = $default_url ;
if ( false !== getenv ( 'WP_UPDATE_HTTPS_URL' ) ) {
$update_url = getenv ( 'WP_UPDATE_HTTPS_URL' );
}
/**
* Filters the URL to learn more about updating the HTTPS version the site is running on .
*
* Providing an empty string is not allowed and will result in the default URL being used . Furthermore
* the page the URL links to should preferably be localized in the site language .
*
* @ since 5.7 . 0
*
* @ param string $update_url URL to learn more about updating HTTPS .
*/
$update_url = apply_filters ( 'wp_update_https_url' , $update_url );
if ( empty ( $update_url ) ) {
$update_url = $default_url ;
}
return $update_url ;
}
/**
* Gets the default URL to learn more about updating the site to use HTTPS .
*
* Do not use this function to retrieve this URL . Instead , use { @ see wp_get_update_https_url ()} when relying on the URL .
* This function does not allow modifying the returned URL , and is only used to compare the actually used URL with the
* default one .
*
* @ since 5.7 . 0
* @ access private
*
* @ return string Default URL to learn more about updating to HTTPS .
*/
function wp_get_default_update_https_url () {
/* translators: Documentation explaining HTTPS and why it should be used. */
2023-02-23 05:38:21 -05:00
return __ ( 'https://wordpress.org/documentation/article/why-should-i-use-https/' );
Security, Site Health: Make migrating a site to HTTPS a one-click interaction.
Switching a WordPress site from HTTP to HTTPS has historically been a tedious task. While on the surface the Site Address and WordPress Address have to be updated, existing content still remains using HTTP URLs where hard-coded in the database. Furthermore, updating _two_ URLs to migrate to HTTPS is still a fairly unintuitive step which is not clearly explained.
This changeset simplifies migration from HTTP to HTTPS and, where possible, makes it a one-click interaction.
* Automatically replace insecure versions of the Site Address (`home_url()`) with its HTTPS counterpart on the fly if the site has been migrated from HTTP to HTTPS. This is accomplished by introducing a `https_migration_required` option and enabling it when the `home_url()` is accordingly changed.
* A new `wp_replace_insecure_home_url()` function is hooked into various pieces of content to replace URLs accordingly.
* The migration only kicks in when the Site Address (`home_url()`) and WordPress Address (`site_url()`) match, which is the widely common case. Configurations where these differ are often maintained by more advanced users, where this migration routine would be less essential - something to potentially iterate on in the future though.
* The migration does not actually update content in the database. More savvy users that prefer to do that can prevent the migration logic from running by either deleting the `https_migration_required` option or using the new `wp_should_replace_insecure_home_url` filter.
* For fresh sites that do not have any content yet at the point of changing the URLs to HTTPS, the migration will also be skipped since it would not be relevant.
* Expose a primary action in the Site Health recommendation, if HTTPS is already supported by the environment, built on top of the HTTPS detection mechanism from [49904]. When clicked, the default behavior is to update `home_url()` and `site_url()` in one go to their HTTPS counterpart.
* A new `wp_update_urls_to_https()` function takes care of the update routine.
* A new `update_https` meta capability is introduced to control access.
* If the site's URLs are controlled by constants, this update is not automatically possible, so in these scenarios the user is informed about that in the HTTPS status check in Site Health.
* Allow hosting providers to modify the URLs linked to in the HTTPS status check in Site Health, similar to how that is possible for the URLs around updating the PHP version.
* A `WP_UPDATE_HTTPS_URL` environment variable or `wp_update_https_url` filter can be used to provide a custom URL with guidance about updating the site to use HTTPS.
* A `WP_DIRECT_UPDATE_HTTPS_URL` environment variable or `wp_direct_update_https_url` filter can be used to provide a custom URL for the primary CTA to update the site to use HTTPS.
Props flixos90, timothyblynjacobs.
Fixes #51437.
Built from https://develop.svn.wordpress.org/trunk@50131
git-svn-id: http://core.svn.wordpress.org/trunk@49810 1a063a9b-81f0-0310-95a4-ce76da25c4cd
2021-02-01 19:10:01 -05:00
}
/**
* Gets the URL for directly updating the site to use HTTPS .
*
* A URL will only be returned if the `WP_DIRECT_UPDATE_HTTPS_URL` environment variable is specified or
* by using the { @ see 'wp_direct_update_https_url' } filter . This allows hosts to send users directly to
* the page where they can update their site to use HTTPS .
*
* @ since 5.7 . 0
*
* @ return string URL for directly updating to HTTPS or empty string .
*/
function wp_get_direct_update_https_url () {
$direct_update_url = '' ;
if ( false !== getenv ( 'WP_DIRECT_UPDATE_HTTPS_URL' ) ) {
$direct_update_url = getenv ( 'WP_DIRECT_UPDATE_HTTPS_URL' );
}
/**
* Filters the URL for directly updating the PHP version the site is running on from the host .
*
* @ since 5.7 . 0
*
* @ param string $direct_update_url URL for directly updating PHP .
*/
$direct_update_url = apply_filters ( 'wp_direct_update_https_url' , $direct_update_url );
return $direct_update_url ;
}
2019-04-02 19:33:53 -04:00
/**
2022-08-12 05:53:11 -04:00
* Gets the size of a directory .
2019-04-02 19:33:53 -04:00
*
* A helper function that is used primarily to check whether
* a blog has exceeded its allowed upload space .
*
* @ since MU ( 3.0 . 0 )
2019-04-04 17:54:53 -04:00
* @ since 5.2 . 0 $max_execution_time parameter added .
2019-04-02 19:33:53 -04:00
*
* @ param string $directory Full path of a directory .
* @ param int $max_execution_time Maximum time to run before giving up . In seconds .
* The timeout is global and is measured from the moment WordPress started to load .
2019-04-19 09:39:52 -04:00
* @ return int | false | null Size in bytes if a valid directory . False if not . Null if timeout .
2019-04-02 19:33:53 -04:00
*/
function get_dirsize ( $directory , $max_execution_time = null ) {
2023-07-10 18:38:25 -04:00
/*
* Exclude individual site directories from the total when checking the main site of a network ,
* as they are subdirectories and should not be counted .
*/
2019-04-02 19:33:53 -04:00
if ( is_multisite () && is_main_site () ) {
2020-10-19 17:51:06 -04:00
$size = recurse_dirsize ( $directory , $directory . '/sites' , $max_execution_time );
2019-04-02 19:33:53 -04:00
} else {
2020-10-19 17:51:06 -04:00
$size = recurse_dirsize ( $directory , null , $max_execution_time );
2019-04-02 19:33:53 -04:00
}
2020-10-19 17:51:06 -04:00
return $size ;
2019-04-02 19:33:53 -04:00
}
/**
2022-08-12 05:53:11 -04:00
* Gets the size of a directory recursively .
2019-04-02 19:33:53 -04:00
*
2020-11-17 10:38:10 -05:00
* Used by get_dirsize () to get a directory size when it contains other directories .
2019-04-02 19:33:53 -04:00
*
* @ since MU ( 3.0 . 0 )
2020-11-17 10:38:10 -05:00
* @ since 4.3 . 0 The `$exclude` parameter was added .
* @ since 5.2 . 0 The `$max_execution_time` parameter was added .
* @ since 5.6 . 0 The `$directory_cache` parameter was added .
2019-04-02 19:33:53 -04:00
*
2021-11-18 08:50:05 -05:00
* @ param string $directory Full path of a directory .
* @ param string | string [] $exclude Optional . Full path of a subdirectory to exclude from the total ,
* or array of paths . Expected without trailing slash ( es ) .
2023-02-21 11:39:19 -05:00
* Default null .
2021-11-18 08:50:05 -05:00
* @ param int $max_execution_time Optional . Maximum time to run before giving up . In seconds .
* The timeout is global and is measured from the moment
2023-02-21 11:39:19 -05:00
* WordPress started to load . Defaults to the value of
* `max_execution_time` PHP setting .
2021-11-18 08:50:05 -05:00
* @ param array $directory_cache Optional . Array of cached directory paths .
2023-02-21 11:39:19 -05:00
* Defaults to the value of `dirsize_cache` transient .
2019-04-16 19:02:51 -04:00
* @ return int | false | null Size in bytes if a valid directory . False if not . Null if timeout .
2019-04-02 19:33:53 -04:00
*/
2020-10-19 17:51:06 -04:00
function recurse_dirsize ( $directory , $exclude = null , $max_execution_time = null , & $directory_cache = null ) {
2020-10-20 09:29:08 -04:00
$directory = untrailingslashit ( $directory );
2020-10-19 17:51:06 -04:00
$save_cache = false ;
if ( ! isset ( $directory_cache ) ) {
$directory_cache = get_transient ( 'dirsize_cache' );
$save_cache = true ;
}
Multisite: Cache absolute `dirsize` paths to avoid PHP 8 fatal.
r49212 greatly improved the performance of `get_dirsize()`, but also changed the structure of the data stored in the `dirsize_cache` transient. It stored relative paths instead of absolute ones, and also removed the unnecessary `size` array.
That difference in data structures led to a fatal error in the following environment:
* PHP 8
* Multisite
* A custom `WP_CONTENT_DIR` which is not a child of WP's `ABSPATH` folder (e.g., [https://roots.io/bedrock/ Bedrock])
* The `upload_space_check_disabled` option set to `0`
After upgrading to WP 5.6, the `dirsize_cache` transient still had data in the old format. When `wp-admin.php/index.php` was visited, `get_space_used()` received an `array` instead of an `int`, and tried to divide it by another `int`. PHP 7 would silently cast the arguments to match data types, but [https://wiki.php.net/rfc/arithmetic_operator_type_checks PHP 8 throws a fatal error]:
`Uncaught TypeError: Unsupported operand types: array / int`
`recurse_dirsize()` was using `ABSPATH` to convert the absolute paths to relative ones, but some upload locations are not located under `ABSPATH`. In those cases, `$directory` and `$cache_path` were identical, and that triggered the early return of the old `array`, instead of the expected `int`.
In order to avoid that, this commit restores the absolute paths, but without the `size` array. It also adds a type check when returning cached values. Using absolute paths without `size` has the result of overwriting the old data, so that it matches the new format. The type check and upgrade routine are additional safety measures.
Props peterwilsoncc, janthiel, helen, hellofromtonya, francina, pbiron.
Fixes #51913. See #19879.
Built from https://develop.svn.wordpress.org/trunk@49744
git-svn-id: http://core.svn.wordpress.org/trunk@49467 1a063a9b-81f0-0310-95a4-ce76da25c4cd
2020-12-03 15:39:02 -05:00
if ( isset ( $directory_cache [ $directory ] ) && is_int ( $directory_cache [ $directory ] ) ) {
return $directory_cache [ $directory ];
2020-10-19 17:51:06 -04:00
}
2019-04-02 19:33:53 -04:00
2019-04-16 19:02:51 -04:00
if ( ! file_exists ( $directory ) || ! is_dir ( $directory ) || ! is_readable ( $directory ) ) {
return false ;
}
if (
( is_string ( $exclude ) && $directory === $exclude ) ||
( is_array ( $exclude ) && in_array ( $directory , $exclude , true ) )
) {
2019-04-02 19:33:53 -04:00
return false ;
}
2020-02-09 11:55:09 -05:00
if ( null === $max_execution_time ) {
2019-04-04 17:54:53 -04:00
// Keep the previous behavior but attempt to prevent fatal errors from timeout if possible.
2019-04-02 19:33:53 -04:00
if ( function_exists ( 'ini_get' ) ) {
$max_execution_time = ini_get ( 'max_execution_time' );
} else {
2019-04-04 17:54:53 -04:00
// Disable...
$max_execution_time = 0 ;
2019-04-02 19:33:53 -04:00
}
// Leave 1 second "buffer" for other operations if $max_execution_time has reasonable value.
if ( $max_execution_time > 10 ) {
$max_execution_time -= 1 ;
}
}
2020-10-19 17:51:06 -04:00
/**
2020-11-17 10:38:10 -05:00
* Filters the amount of storage space used by one directory and all its children , in megabytes .
*
* Return the actual used space to short - circuit the recursive PHP file size calculation
* and use something else , like a CDN API or native operating system tools for better performance .
*
* @ since 5.6 . 0
*
2021-11-18 08:50:05 -05:00
* @ param int | false $space_used The amount of used space , in bytes . Default false .
* @ param string $directory Full path of a directory .
* @ param string | string [] | null $exclude Full path of a subdirectory to exclude from the total ,
* or array of paths .
* @ param int $max_execution_time Maximum time to run before giving up . In seconds .
* @ param array $directory_cache Array of cached directory paths .
2020-11-17 10:38:10 -05:00
*/
2020-11-17 10:44:07 -05:00
$size = apply_filters ( 'pre_recurse_dirsize' , false , $directory , $exclude , $max_execution_time , $directory_cache );
if ( false === $size ) {
$size = 0 ;
2020-10-19 17:51:06 -04:00
$handle = opendir ( $directory );
if ( $handle ) {
while ( ( $file = readdir ( $handle ) ) !== false ) {
$path = $directory . '/' . $file ;
if ( '.' !== $file && '..' !== $file ) {
if ( is_file ( $path ) ) {
$size += filesize ( $path );
} elseif ( is_dir ( $path ) ) {
$handlesize = recurse_dirsize ( $path , $exclude , $max_execution_time , $directory_cache );
if ( $handlesize > 0 ) {
$size += $handlesize ;
}
2019-04-02 19:33:53 -04:00
}
FileSystem API: Fix autovivification deprecation notice in `recurse_dirsize()`.
>PHP natively allows for autovivification (auto-creation of arrays from falsey values). This feature is very useful and used in a lot of PHP projects, especially if the variable is undefined. However, there is a little oddity that allows creating an array from a `false` and `null` value.
The above quote is from the PHP 8.1 RFC and the (accepted) RFC changes the behaviour described above to deprecated auto creation of arrays from `false`. As it is deprecated, it _will_ still work for the time being, but as of PHP 9.0, this will become a Fatal Error, so we may as well fix it now.
The `recurse_dirsize()` function retrieves a transient and places it in the `$directory_cache` variable, but the `get_transient()` function in WP returns `false` when the transient doesn't exist, which subsequently can lead to the above mentioned deprecation notice.
By verifying that the `$directory_cache` variable is an array before assigning to it and initializing it to an empty array, if it's not, we prevent the deprecation notice, as well as harden the function against potentially corrupted transients where this transient would not return the expected array format, but some other variable type.
Includes adding dedicated unit tests for both the PHP 8.1 issue, as well as the hardening against corrupted transients.
Includes some girl-scouting: touching up a parameter description and some code layout.
Refs:
* https://wiki.php.net/rfc/autovivification_false
* https://developer.wordpress.org/reference/functions/get_transient/
Follow-up to [49212], [49744].
Props jrf, hellofromTonya.
See #53635.
Built from https://develop.svn.wordpress.org/trunk@51911
git-svn-id: http://core.svn.wordpress.org/trunk@51504 1a063a9b-81f0-0310-95a4-ce76da25c4cd
2021-10-15 18:53:58 -04:00
if ( $max_execution_time > 0 &&
( microtime ( true ) - WP_START_TIMESTAMP ) > $max_execution_time
) {
2020-10-19 17:51:06 -04:00
// Time exceeded. Give up instead of risking a fatal timeout.
$size = null ;
break ;
}
2019-04-02 19:33:53 -04:00
}
}
2020-10-19 17:51:06 -04:00
closedir ( $handle );
2019-04-02 19:33:53 -04:00
}
}
2020-11-17 10:44:07 -05:00
FileSystem API: Fix autovivification deprecation notice in `recurse_dirsize()`.
>PHP natively allows for autovivification (auto-creation of arrays from falsey values). This feature is very useful and used in a lot of PHP projects, especially if the variable is undefined. However, there is a little oddity that allows creating an array from a `false` and `null` value.
The above quote is from the PHP 8.1 RFC and the (accepted) RFC changes the behaviour described above to deprecated auto creation of arrays from `false`. As it is deprecated, it _will_ still work for the time being, but as of PHP 9.0, this will become a Fatal Error, so we may as well fix it now.
The `recurse_dirsize()` function retrieves a transient and places it in the `$directory_cache` variable, but the `get_transient()` function in WP returns `false` when the transient doesn't exist, which subsequently can lead to the above mentioned deprecation notice.
By verifying that the `$directory_cache` variable is an array before assigning to it and initializing it to an empty array, if it's not, we prevent the deprecation notice, as well as harden the function against potentially corrupted transients where this transient would not return the expected array format, but some other variable type.
Includes adding dedicated unit tests for both the PHP 8.1 issue, as well as the hardening against corrupted transients.
Includes some girl-scouting: touching up a parameter description and some code layout.
Refs:
* https://wiki.php.net/rfc/autovivification_false
* https://developer.wordpress.org/reference/functions/get_transient/
Follow-up to [49212], [49744].
Props jrf, hellofromTonya.
See #53635.
Built from https://develop.svn.wordpress.org/trunk@51911
git-svn-id: http://core.svn.wordpress.org/trunk@51504 1a063a9b-81f0-0310-95a4-ce76da25c4cd
2021-10-15 18:53:58 -04:00
if ( ! is_array ( $directory_cache ) ) {
$directory_cache = array ();
}
Multisite: Cache absolute `dirsize` paths to avoid PHP 8 fatal.
r49212 greatly improved the performance of `get_dirsize()`, but also changed the structure of the data stored in the `dirsize_cache` transient. It stored relative paths instead of absolute ones, and also removed the unnecessary `size` array.
That difference in data structures led to a fatal error in the following environment:
* PHP 8
* Multisite
* A custom `WP_CONTENT_DIR` which is not a child of WP's `ABSPATH` folder (e.g., [https://roots.io/bedrock/ Bedrock])
* The `upload_space_check_disabled` option set to `0`
After upgrading to WP 5.6, the `dirsize_cache` transient still had data in the old format. When `wp-admin.php/index.php` was visited, `get_space_used()` received an `array` instead of an `int`, and tried to divide it by another `int`. PHP 7 would silently cast the arguments to match data types, but [https://wiki.php.net/rfc/arithmetic_operator_type_checks PHP 8 throws a fatal error]:
`Uncaught TypeError: Unsupported operand types: array / int`
`recurse_dirsize()` was using `ABSPATH` to convert the absolute paths to relative ones, but some upload locations are not located under `ABSPATH`. In those cases, `$directory` and `$cache_path` were identical, and that triggered the early return of the old `array`, instead of the expected `int`.
In order to avoid that, this commit restores the absolute paths, but without the `size` array. It also adds a type check when returning cached values. Using absolute paths without `size` has the result of overwriting the old data, so that it matches the new format. The type check and upgrade routine are additional safety measures.
Props peterwilsoncc, janthiel, helen, hellofromtonya, francina, pbiron.
Fixes #51913. See #19879.
Built from https://develop.svn.wordpress.org/trunk@49744
git-svn-id: http://core.svn.wordpress.org/trunk@49467 1a063a9b-81f0-0310-95a4-ce76da25c4cd
2020-12-03 15:39:02 -05:00
$directory_cache [ $directory ] = $size ;
2020-10-19 17:51:06 -04:00
2020-11-17 10:38:10 -05:00
// Only write the transient on the top level call and not on recursive calls.
2020-10-19 17:51:06 -04:00
if ( $save_cache ) {
set_transient ( 'dirsize_cache' , $directory_cache );
}
2019-04-02 19:33:53 -04:00
return $size ;
}
2019-04-12 19:56:52 -04:00
2020-10-19 17:51:06 -04:00
/**
2020-11-17 10:38:10 -05:00
* Cleans directory size cache used by recurse_dirsize () .
2020-10-19 17:51:06 -04:00
*
2020-11-17 10:38:10 -05:00
* Removes the current directory and all parent directories from the `dirsize_cache` transient .
2020-10-19 17:51:06 -04:00
*
* @ since 5.6 . 0
FileSystem API: Fix infinite loop on Windows for `clean_dirsize_cache()`.
When the PHP native `dirname()` function is used on a Windows disk name - i.e. `C:\`-, it will return the same, i.e, it will return `C:\` again.
The `clean_dirsize_cache()` function didn't have guard clause against this, which meant that on Windows based systems and IIS servers, this function would result in WordPress getting stuck into an infinite loop.
The adjustment to the `while` part of the function fix this by checking if the return value of the `dirname()` function call is the same as the original path passed to `dirname()`, which effectively fixes the infinite loop.
A number of other improvements made:
1. Add input validation for the `$path` parameter to guard against invalid variable types being passed into the function.
2. Guard against an empty `$path` parameter, which would result in an infinite loop on both Windows as well as *nix based systems.
In both these cases, a PHP notice will now be thrown.
3. When a non-empty string, which isn't a path would previously be passed, the `dirname()` function would transform that to a `.` and the `.` key in the transient cache would be cleared out.
This was a bug as there is no relation between a non-path string and the root directory of file system.
This bug has been fixed by checking that something could actually be a path and handling received non-empty, non-path input parameters in a special way, i.e only removing the cache key for the passed string and bowing out from further processing.
Unfortunately, no tests can be added to guard against the infinite loop.
For the other fixes, we have added appropriate unit tests.
Follow-up up [49212], [49616], [49744].
Props jrf, hellofromTonya, raubvogel, sergeybiryukov, codezen8, sjlevy, drosmog, teachlynx, ekojr, bartoszgrzesik, joegasper, janthiel, josephdickson, ocean90, audrasjb.
Fixes #52241.
Built from https://develop.svn.wordpress.org/trunk@51910
git-svn-id: http://core.svn.wordpress.org/trunk@51503 1a063a9b-81f0-0310-95a4-ce76da25c4cd
2021-10-15 18:25:01 -04:00
* @ since 5.9 . 0 Added input validation with a notice for invalid input .
2020-10-19 17:51:06 -04:00
*
* @ param string $path Full path of a directory or file .
*/
2020-11-16 17:31:06 -05:00
function clean_dirsize_cache ( $path ) {
FileSystem API: Fix infinite loop on Windows for `clean_dirsize_cache()`.
When the PHP native `dirname()` function is used on a Windows disk name - i.e. `C:\`-, it will return the same, i.e, it will return `C:\` again.
The `clean_dirsize_cache()` function didn't have guard clause against this, which meant that on Windows based systems and IIS servers, this function would result in WordPress getting stuck into an infinite loop.
The adjustment to the `while` part of the function fix this by checking if the return value of the `dirname()` function call is the same as the original path passed to `dirname()`, which effectively fixes the infinite loop.
A number of other improvements made:
1. Add input validation for the `$path` parameter to guard against invalid variable types being passed into the function.
2. Guard against an empty `$path` parameter, which would result in an infinite loop on both Windows as well as *nix based systems.
In both these cases, a PHP notice will now be thrown.
3. When a non-empty string, which isn't a path would previously be passed, the `dirname()` function would transform that to a `.` and the `.` key in the transient cache would be cleared out.
This was a bug as there is no relation between a non-path string and the root directory of file system.
This bug has been fixed by checking that something could actually be a path and handling received non-empty, non-path input parameters in a special way, i.e only removing the cache key for the passed string and bowing out from further processing.
Unfortunately, no tests can be added to guard against the infinite loop.
For the other fixes, we have added appropriate unit tests.
Follow-up up [49212], [49616], [49744].
Props jrf, hellofromTonya, raubvogel, sergeybiryukov, codezen8, sjlevy, drosmog, teachlynx, ekojr, bartoszgrzesik, joegasper, janthiel, josephdickson, ocean90, audrasjb.
Fixes #52241.
Built from https://develop.svn.wordpress.org/trunk@51910
git-svn-id: http://core.svn.wordpress.org/trunk@51503 1a063a9b-81f0-0310-95a4-ce76da25c4cd
2021-10-15 18:25:01 -04:00
if ( ! is_string ( $path ) || empty ( $path ) ) {
trigger_error (
sprintf (
/* translators: 1: Function name, 2: A variable type, like "boolean" or "integer". */
__ ( '%1$s only accepts a non-empty path string, received %2$s.' ),
'<code>clean_dirsize_cache()</code>' ,
'<code>' . gettype ( $path ) . '</code>'
)
);
return ;
}
2020-10-19 17:51:06 -04:00
$directory_cache = get_transient ( 'dirsize_cache' );
if ( empty ( $directory_cache ) ) {
return ;
}
FileSystem API: Fix infinite loop on Windows for `clean_dirsize_cache()`.
When the PHP native `dirname()` function is used on a Windows disk name - i.e. `C:\`-, it will return the same, i.e, it will return `C:\` again.
The `clean_dirsize_cache()` function didn't have guard clause against this, which meant that on Windows based systems and IIS servers, this function would result in WordPress getting stuck into an infinite loop.
The adjustment to the `while` part of the function fix this by checking if the return value of the `dirname()` function call is the same as the original path passed to `dirname()`, which effectively fixes the infinite loop.
A number of other improvements made:
1. Add input validation for the `$path` parameter to guard against invalid variable types being passed into the function.
2. Guard against an empty `$path` parameter, which would result in an infinite loop on both Windows as well as *nix based systems.
In both these cases, a PHP notice will now be thrown.
3. When a non-empty string, which isn't a path would previously be passed, the `dirname()` function would transform that to a `.` and the `.` key in the transient cache would be cleared out.
This was a bug as there is no relation between a non-path string and the root directory of file system.
This bug has been fixed by checking that something could actually be a path and handling received non-empty, non-path input parameters in a special way, i.e only removing the cache key for the passed string and bowing out from further processing.
Unfortunately, no tests can be added to guard against the infinite loop.
For the other fixes, we have added appropriate unit tests.
Follow-up up [49212], [49616], [49744].
Props jrf, hellofromTonya, raubvogel, sergeybiryukov, codezen8, sjlevy, drosmog, teachlynx, ekojr, bartoszgrzesik, joegasper, janthiel, josephdickson, ocean90, audrasjb.
Fixes #52241.
Built from https://develop.svn.wordpress.org/trunk@51910
git-svn-id: http://core.svn.wordpress.org/trunk@51503 1a063a9b-81f0-0310-95a4-ce76da25c4cd
2021-10-15 18:25:01 -04:00
if (
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 10:36:26 -04:00
! str_contains ( $path , '/' ) &&
! str_contains ( $path , '\\' )
FileSystem API: Fix infinite loop on Windows for `clean_dirsize_cache()`.
When the PHP native `dirname()` function is used on a Windows disk name - i.e. `C:\`-, it will return the same, i.e, it will return `C:\` again.
The `clean_dirsize_cache()` function didn't have guard clause against this, which meant that on Windows based systems and IIS servers, this function would result in WordPress getting stuck into an infinite loop.
The adjustment to the `while` part of the function fix this by checking if the return value of the `dirname()` function call is the same as the original path passed to `dirname()`, which effectively fixes the infinite loop.
A number of other improvements made:
1. Add input validation for the `$path` parameter to guard against invalid variable types being passed into the function.
2. Guard against an empty `$path` parameter, which would result in an infinite loop on both Windows as well as *nix based systems.
In both these cases, a PHP notice will now be thrown.
3. When a non-empty string, which isn't a path would previously be passed, the `dirname()` function would transform that to a `.` and the `.` key in the transient cache would be cleared out.
This was a bug as there is no relation between a non-path string and the root directory of file system.
This bug has been fixed by checking that something could actually be a path and handling received non-empty, non-path input parameters in a special way, i.e only removing the cache key for the passed string and bowing out from further processing.
Unfortunately, no tests can be added to guard against the infinite loop.
For the other fixes, we have added appropriate unit tests.
Follow-up up [49212], [49616], [49744].
Props jrf, hellofromTonya, raubvogel, sergeybiryukov, codezen8, sjlevy, drosmog, teachlynx, ekojr, bartoszgrzesik, joegasper, janthiel, josephdickson, ocean90, audrasjb.
Fixes #52241.
Built from https://develop.svn.wordpress.org/trunk@51910
git-svn-id: http://core.svn.wordpress.org/trunk@51503 1a063a9b-81f0-0310-95a4-ce76da25c4cd
2021-10-15 18:25:01 -04:00
) {
unset ( $directory_cache [ $path ] );
set_transient ( 'dirsize_cache' , $directory_cache );
return ;
}
$last_path = null ;
$path = untrailingslashit ( $path );
Multisite: Cache absolute `dirsize` paths to avoid PHP 8 fatal.
r49212 greatly improved the performance of `get_dirsize()`, but also changed the structure of the data stored in the `dirsize_cache` transient. It stored relative paths instead of absolute ones, and also removed the unnecessary `size` array.
That difference in data structures led to a fatal error in the following environment:
* PHP 8
* Multisite
* A custom `WP_CONTENT_DIR` which is not a child of WP's `ABSPATH` folder (e.g., [https://roots.io/bedrock/ Bedrock])
* The `upload_space_check_disabled` option set to `0`
After upgrading to WP 5.6, the `dirsize_cache` transient still had data in the old format. When `wp-admin.php/index.php` was visited, `get_space_used()` received an `array` instead of an `int`, and tried to divide it by another `int`. PHP 7 would silently cast the arguments to match data types, but [https://wiki.php.net/rfc/arithmetic_operator_type_checks PHP 8 throws a fatal error]:
`Uncaught TypeError: Unsupported operand types: array / int`
`recurse_dirsize()` was using `ABSPATH` to convert the absolute paths to relative ones, but some upload locations are not located under `ABSPATH`. In those cases, `$directory` and `$cache_path` were identical, and that triggered the early return of the old `array`, instead of the expected `int`.
In order to avoid that, this commit restores the absolute paths, but without the `size` array. It also adds a type check when returning cached values. Using absolute paths without `size` has the result of overwriting the old data, so that it matches the new format. The type check and upgrade routine are additional safety measures.
Props peterwilsoncc, janthiel, helen, hellofromtonya, francina, pbiron.
Fixes #51913. See #19879.
Built from https://develop.svn.wordpress.org/trunk@49744
git-svn-id: http://core.svn.wordpress.org/trunk@49467 1a063a9b-81f0-0310-95a4-ce76da25c4cd
2020-12-03 15:39:02 -05:00
unset ( $directory_cache [ $path ] );
2020-10-19 17:51:06 -04:00
FileSystem API: Fix infinite loop on Windows for `clean_dirsize_cache()`.
When the PHP native `dirname()` function is used on a Windows disk name - i.e. `C:\`-, it will return the same, i.e, it will return `C:\` again.
The `clean_dirsize_cache()` function didn't have guard clause against this, which meant that on Windows based systems and IIS servers, this function would result in WordPress getting stuck into an infinite loop.
The adjustment to the `while` part of the function fix this by checking if the return value of the `dirname()` function call is the same as the original path passed to `dirname()`, which effectively fixes the infinite loop.
A number of other improvements made:
1. Add input validation for the `$path` parameter to guard against invalid variable types being passed into the function.
2. Guard against an empty `$path` parameter, which would result in an infinite loop on both Windows as well as *nix based systems.
In both these cases, a PHP notice will now be thrown.
3. When a non-empty string, which isn't a path would previously be passed, the `dirname()` function would transform that to a `.` and the `.` key in the transient cache would be cleared out.
This was a bug as there is no relation between a non-path string and the root directory of file system.
This bug has been fixed by checking that something could actually be a path and handling received non-empty, non-path input parameters in a special way, i.e only removing the cache key for the passed string and bowing out from further processing.
Unfortunately, no tests can be added to guard against the infinite loop.
For the other fixes, we have added appropriate unit tests.
Follow-up up [49212], [49616], [49744].
Props jrf, hellofromTonya, raubvogel, sergeybiryukov, codezen8, sjlevy, drosmog, teachlynx, ekojr, bartoszgrzesik, joegasper, janthiel, josephdickson, ocean90, audrasjb.
Fixes #52241.
Built from https://develop.svn.wordpress.org/trunk@51910
git-svn-id: http://core.svn.wordpress.org/trunk@51503 1a063a9b-81f0-0310-95a4-ce76da25c4cd
2021-10-15 18:25:01 -04:00
while (
$last_path !== $path &&
DIRECTORY_SEPARATOR !== $path &&
'.' !== $path &&
'..' !== $path
) {
$last_path = $path ;
$path = dirname ( $path );
Multisite: Cache absolute `dirsize` paths to avoid PHP 8 fatal.
r49212 greatly improved the performance of `get_dirsize()`, but also changed the structure of the data stored in the `dirsize_cache` transient. It stored relative paths instead of absolute ones, and also removed the unnecessary `size` array.
That difference in data structures led to a fatal error in the following environment:
* PHP 8
* Multisite
* A custom `WP_CONTENT_DIR` which is not a child of WP's `ABSPATH` folder (e.g., [https://roots.io/bedrock/ Bedrock])
* The `upload_space_check_disabled` option set to `0`
After upgrading to WP 5.6, the `dirsize_cache` transient still had data in the old format. When `wp-admin.php/index.php` was visited, `get_space_used()` received an `array` instead of an `int`, and tried to divide it by another `int`. PHP 7 would silently cast the arguments to match data types, but [https://wiki.php.net/rfc/arithmetic_operator_type_checks PHP 8 throws a fatal error]:
`Uncaught TypeError: Unsupported operand types: array / int`
`recurse_dirsize()` was using `ABSPATH` to convert the absolute paths to relative ones, but some upload locations are not located under `ABSPATH`. In those cases, `$directory` and `$cache_path` were identical, and that triggered the early return of the old `array`, instead of the expected `int`.
In order to avoid that, this commit restores the absolute paths, but without the `size` array. It also adds a type check when returning cached values. Using absolute paths without `size` has the result of overwriting the old data, so that it matches the new format. The type check and upgrade routine are additional safety measures.
Props peterwilsoncc, janthiel, helen, hellofromtonya, francina, pbiron.
Fixes #51913. See #19879.
Built from https://develop.svn.wordpress.org/trunk@49744
git-svn-id: http://core.svn.wordpress.org/trunk@49467 1a063a9b-81f0-0310-95a4-ce76da25c4cd
2020-12-03 15:39:02 -05:00
unset ( $directory_cache [ $path ] );
2020-10-19 17:51:06 -04:00
}
set_transient ( 'dirsize_cache' , $directory_cache );
}
2019-04-12 19:56:52 -04:00
/**
2019-07-09 01:45:58 -04:00
* Checks compatibility with the current WordPress version .
*
* @ since 5.2 . 0
*
2022-04-04 14:26:06 -04:00
* @ global string $wp_version The WordPress version string .
2022-01-24 05:41:01 -05:00
*
2019-07-09 01:45:58 -04:00
* @ param string $required Minimum required WordPress version .
* @ return bool True if required version is compatible or empty , false if not .
*/
2019-04-12 19:56:52 -04:00
function is_wp_version_compatible ( $required ) {
2022-01-24 05:41:01 -05:00
global $wp_version ;
// Strip off any -alpha, -RC, -beta, -src suffixes.
list ( $version ) = explode ( '-' , $wp_version );
return empty ( $required ) || version_compare ( $version , $required , '>=' );
2019-04-12 19:56:52 -04:00
}
/**
* Checks compatibility with the current PHP version .
*
* @ since 5.2 . 0
*
* @ param string $required Minimum required PHP version .
* @ return bool True if required version is compatible or empty , false if not .
*/
function is_php_version_compatible ( $required ) {
2022-05-20 13:38:14 -04:00
return empty ( $required ) || version_compare ( PHP_VERSION , $required , '>=' );
2019-04-12 19:56:52 -04:00
}
2019-09-06 21:34:55 -04:00
/**
2022-03-31 04:17:06 -04:00
* Checks if two numbers are nearly the same .
2019-09-06 22:12:55 -04:00
*
2019-09-06 21:34:55 -04:00
* This is similar to using `round()` but the precision is more fine - grained .
*
* @ since 5.3 . 0
2019-09-06 22:12:55 -04:00
*
2019-09-06 21:34:55 -04:00
* @ param int | float $expected The expected value .
* @ param int | float $actual The actual number .
* @ param int | float $precision The allowed variation .
2022-03-31 04:17:06 -04:00
* @ return bool Whether the numbers match within the specified precision .
2019-09-06 21:34:55 -04:00
*/
function wp_fuzzy_number_match ( $expected , $actual , $precision = 1 ) {
return abs ( ( float ) $expected - ( float ) $actual ) <= $precision ;
}