Edit File by line

Deprecated: str_replace(): Passing null to parameter #2 ($replace) of type array|string is deprecated in /home/sportsfever/public_html/filemanger/function.php on line 93

Warning: Undefined array key "page_file_edit_line" in /home/sportsfever/public_html/filemanger/edit_text_line.php on line 32
/home/sportsfe.../httpdocs/clone/wp-inclu...
File: class-wp-date-query.php
* @since 3.7.0
[500] Fix | Delete
* @since 4.1.0 Added 'user_registered' to the default recognized columns.
[501] Fix | Delete
* @since 4.6.0 Added 'registered' and 'last_updated' to the default recognized columns.
[502] Fix | Delete
*
[503] Fix | Delete
* @param string[] $valid_columns An array of valid date query columns. Defaults
[504] Fix | Delete
* are 'post_date', 'post_date_gmt', 'post_modified',
[505] Fix | Delete
* 'post_modified_gmt', 'comment_date', 'comment_date_gmt',
[506] Fix | Delete
* 'user_registered', 'registered', 'last_updated'.
[507] Fix | Delete
*/
[508] Fix | Delete
if ( ! in_array( $column, apply_filters( 'date_query_valid_columns', $valid_columns ), true ) ) {
[509] Fix | Delete
$column = 'post_date';
[510] Fix | Delete
}
[511] Fix | Delete
[512] Fix | Delete
$known_columns = array(
[513] Fix | Delete
$wpdb->posts => array(
[514] Fix | Delete
'post_date',
[515] Fix | Delete
'post_date_gmt',
[516] Fix | Delete
'post_modified',
[517] Fix | Delete
'post_modified_gmt',
[518] Fix | Delete
),
[519] Fix | Delete
$wpdb->comments => array(
[520] Fix | Delete
'comment_date',
[521] Fix | Delete
'comment_date_gmt',
[522] Fix | Delete
),
[523] Fix | Delete
$wpdb->users => array(
[524] Fix | Delete
'user_registered',
[525] Fix | Delete
),
[526] Fix | Delete
$wpdb->blogs => array(
[527] Fix | Delete
'registered',
[528] Fix | Delete
'last_updated',
[529] Fix | Delete
),
[530] Fix | Delete
);
[531] Fix | Delete
[532] Fix | Delete
// If it's a known column name, add the appropriate table prefix.
[533] Fix | Delete
foreach ( $known_columns as $table_name => $table_columns ) {
[534] Fix | Delete
if ( in_array( $column, $table_columns, true ) ) {
[535] Fix | Delete
$column = $table_name . '.' . $column;
[536] Fix | Delete
break;
[537] Fix | Delete
}
[538] Fix | Delete
}
[539] Fix | Delete
}
[540] Fix | Delete
[541] Fix | Delete
// Remove unsafe characters.
[542] Fix | Delete
return preg_replace( '/[^a-zA-Z0-9_$\.]/', '', $column );
[543] Fix | Delete
}
[544] Fix | Delete
[545] Fix | Delete
/**
[546] Fix | Delete
* Generates WHERE clause to be appended to a main query.
[547] Fix | Delete
*
[548] Fix | Delete
* @since 3.7.0
[549] Fix | Delete
*
[550] Fix | Delete
* @return string MySQL WHERE clause.
[551] Fix | Delete
*/
[552] Fix | Delete
public function get_sql() {
[553] Fix | Delete
$sql = $this->get_sql_clauses();
[554] Fix | Delete
[555] Fix | Delete
$where = $sql['where'];
[556] Fix | Delete
[557] Fix | Delete
/**
[558] Fix | Delete
* Filters the date query WHERE clause.
[559] Fix | Delete
*
[560] Fix | Delete
* @since 3.7.0
[561] Fix | Delete
*
[562] Fix | Delete
* @param string $where WHERE clause of the date query.
[563] Fix | Delete
* @param WP_Date_Query $query The WP_Date_Query instance.
[564] Fix | Delete
*/
[565] Fix | Delete
return apply_filters( 'get_date_sql', $where, $this );
[566] Fix | Delete
}
[567] Fix | Delete
[568] Fix | Delete
/**
[569] Fix | Delete
* Generates SQL clauses to be appended to a main query.
[570] Fix | Delete
*
[571] Fix | Delete
* Called by the public WP_Date_Query::get_sql(), this method is abstracted
[572] Fix | Delete
* out to maintain parity with the other Query classes.
[573] Fix | Delete
*
[574] Fix | Delete
* @since 4.1.0
[575] Fix | Delete
*
[576] Fix | Delete
* @return string[] {
[577] Fix | Delete
* Array containing JOIN and WHERE SQL clauses to append to the main query.
[578] Fix | Delete
*
[579] Fix | Delete
* @type string $join SQL fragment to append to the main JOIN clause.
[580] Fix | Delete
* @type string $where SQL fragment to append to the main WHERE clause.
[581] Fix | Delete
* }
[582] Fix | Delete
*/
[583] Fix | Delete
protected function get_sql_clauses() {
[584] Fix | Delete
$sql = $this->get_sql_for_query( $this->queries );
[585] Fix | Delete
[586] Fix | Delete
if ( ! empty( $sql['where'] ) ) {
[587] Fix | Delete
$sql['where'] = ' AND ' . $sql['where'];
[588] Fix | Delete
}
[589] Fix | Delete
[590] Fix | Delete
return $sql;
[591] Fix | Delete
}
[592] Fix | Delete
[593] Fix | Delete
/**
[594] Fix | Delete
* Generates SQL clauses for a single query array.
[595] Fix | Delete
*
[596] Fix | Delete
* If nested subqueries are found, this method recurses the tree to
[597] Fix | Delete
* produce the properly nested SQL.
[598] Fix | Delete
*
[599] Fix | Delete
* @since 4.1.0
[600] Fix | Delete
*
[601] Fix | Delete
* @param array $query Query to parse.
[602] Fix | Delete
* @param int $depth Optional. Number of tree levels deep we currently are.
[603] Fix | Delete
* Used to calculate indentation. Default 0.
[604] Fix | Delete
* @return array {
[605] Fix | Delete
* Array containing JOIN and WHERE SQL clauses to append to a single query array.
[606] Fix | Delete
*
[607] Fix | Delete
* @type string $join SQL fragment to append to the main JOIN clause.
[608] Fix | Delete
* @type string $where SQL fragment to append to the main WHERE clause.
[609] Fix | Delete
* }
[610] Fix | Delete
*/
[611] Fix | Delete
protected function get_sql_for_query( $query, $depth = 0 ) {
[612] Fix | Delete
$sql_chunks = array(
[613] Fix | Delete
'join' => array(),
[614] Fix | Delete
'where' => array(),
[615] Fix | Delete
);
[616] Fix | Delete
[617] Fix | Delete
$sql = array(
[618] Fix | Delete
'join' => '',
[619] Fix | Delete
'where' => '',
[620] Fix | Delete
);
[621] Fix | Delete
[622] Fix | Delete
$indent = '';
[623] Fix | Delete
for ( $i = 0; $i < $depth; $i++ ) {
[624] Fix | Delete
$indent .= ' ';
[625] Fix | Delete
}
[626] Fix | Delete
[627] Fix | Delete
foreach ( $query as $key => $clause ) {
[628] Fix | Delete
if ( 'relation' === $key ) {
[629] Fix | Delete
$relation = $query['relation'];
[630] Fix | Delete
} elseif ( is_array( $clause ) ) {
[631] Fix | Delete
[632] Fix | Delete
// This is a first-order clause.
[633] Fix | Delete
if ( $this->is_first_order_clause( $clause ) ) {
[634] Fix | Delete
$clause_sql = $this->get_sql_for_clause( $clause, $query );
[635] Fix | Delete
[636] Fix | Delete
$where_count = count( $clause_sql['where'] );
[637] Fix | Delete
if ( ! $where_count ) {
[638] Fix | Delete
$sql_chunks['where'][] = '';
[639] Fix | Delete
} elseif ( 1 === $where_count ) {
[640] Fix | Delete
$sql_chunks['where'][] = $clause_sql['where'][0];
[641] Fix | Delete
} else {
[642] Fix | Delete
$sql_chunks['where'][] = '( ' . implode( ' AND ', $clause_sql['where'] ) . ' )';
[643] Fix | Delete
}
[644] Fix | Delete
[645] Fix | Delete
$sql_chunks['join'] = array_merge( $sql_chunks['join'], $clause_sql['join'] );
[646] Fix | Delete
// This is a subquery, so we recurse.
[647] Fix | Delete
} else {
[648] Fix | Delete
$clause_sql = $this->get_sql_for_query( $clause, $depth + 1 );
[649] Fix | Delete
[650] Fix | Delete
$sql_chunks['where'][] = $clause_sql['where'];
[651] Fix | Delete
$sql_chunks['join'][] = $clause_sql['join'];
[652] Fix | Delete
}
[653] Fix | Delete
}
[654] Fix | Delete
}
[655] Fix | Delete
[656] Fix | Delete
// Filter to remove empties.
[657] Fix | Delete
$sql_chunks['join'] = array_filter( $sql_chunks['join'] );
[658] Fix | Delete
$sql_chunks['where'] = array_filter( $sql_chunks['where'] );
[659] Fix | Delete
[660] Fix | Delete
if ( empty( $relation ) ) {
[661] Fix | Delete
$relation = 'AND';
[662] Fix | Delete
}
[663] Fix | Delete
[664] Fix | Delete
// Filter duplicate JOIN clauses and combine into a single string.
[665] Fix | Delete
if ( ! empty( $sql_chunks['join'] ) ) {
[666] Fix | Delete
$sql['join'] = implode( ' ', array_unique( $sql_chunks['join'] ) );
[667] Fix | Delete
}
[668] Fix | Delete
[669] Fix | Delete
// Generate a single WHERE clause with proper brackets and indentation.
[670] Fix | Delete
if ( ! empty( $sql_chunks['where'] ) ) {
[671] Fix | Delete
$sql['where'] = '( ' . "\n " . $indent . implode( ' ' . "\n " . $indent . $relation . ' ' . "\n " . $indent, $sql_chunks['where'] ) . "\n" . $indent . ')';
[672] Fix | Delete
}
[673] Fix | Delete
[674] Fix | Delete
return $sql;
[675] Fix | Delete
}
[676] Fix | Delete
[677] Fix | Delete
/**
[678] Fix | Delete
* Turns a single date clause into pieces for a WHERE clause.
[679] Fix | Delete
*
[680] Fix | Delete
* A wrapper for get_sql_for_clause(), included here for backward
[681] Fix | Delete
* compatibility while retaining the naming convention across Query classes.
[682] Fix | Delete
*
[683] Fix | Delete
* @since 3.7.0
[684] Fix | Delete
*
[685] Fix | Delete
* @param array $query Date query arguments.
[686] Fix | Delete
* @return array {
[687] Fix | Delete
* Array containing JOIN and WHERE SQL clauses to append to the main query.
[688] Fix | Delete
*
[689] Fix | Delete
* @type string[] $join Array of SQL fragments to append to the main JOIN clause.
[690] Fix | Delete
* @type string[] $where Array of SQL fragments to append to the main WHERE clause.
[691] Fix | Delete
* }
[692] Fix | Delete
*/
[693] Fix | Delete
protected function get_sql_for_subquery( $query ) {
[694] Fix | Delete
return $this->get_sql_for_clause( $query, '' );
[695] Fix | Delete
}
[696] Fix | Delete
[697] Fix | Delete
/**
[698] Fix | Delete
* Turns a first-order date query into SQL for a WHERE clause.
[699] Fix | Delete
*
[700] Fix | Delete
* @since 4.1.0
[701] Fix | Delete
*
[702] Fix | Delete
* @global wpdb $wpdb WordPress database abstraction object.
[703] Fix | Delete
*
[704] Fix | Delete
* @param array $query Date query clause.
[705] Fix | Delete
* @param array $parent_query Parent query of the current date query.
[706] Fix | Delete
* @return array {
[707] Fix | Delete
* Array containing JOIN and WHERE SQL clauses to append to the main query.
[708] Fix | Delete
*
[709] Fix | Delete
* @type string[] $join Array of SQL fragments to append to the main JOIN clause.
[710] Fix | Delete
* @type string[] $where Array of SQL fragments to append to the main WHERE clause.
[711] Fix | Delete
* }
[712] Fix | Delete
*/
[713] Fix | Delete
protected function get_sql_for_clause( $query, $parent_query ) {
[714] Fix | Delete
global $wpdb;
[715] Fix | Delete
[716] Fix | Delete
// The sub-parts of a $where part.
[717] Fix | Delete
$where_parts = array();
[718] Fix | Delete
[719] Fix | Delete
$column = ( ! empty( $query['column'] ) ) ? esc_sql( $query['column'] ) : $this->column;
[720] Fix | Delete
[721] Fix | Delete
$column = $this->validate_column( $column );
[722] Fix | Delete
[723] Fix | Delete
$compare = $this->get_compare( $query );
[724] Fix | Delete
[725] Fix | Delete
$inclusive = ! empty( $query['inclusive'] );
[726] Fix | Delete
[727] Fix | Delete
// Assign greater- and less-than values.
[728] Fix | Delete
$lt = '<';
[729] Fix | Delete
$gt = '>';
[730] Fix | Delete
[731] Fix | Delete
if ( $inclusive ) {
[732] Fix | Delete
$lt .= '=';
[733] Fix | Delete
$gt .= '=';
[734] Fix | Delete
}
[735] Fix | Delete
[736] Fix | Delete
// Range queries.
[737] Fix | Delete
if ( ! empty( $query['after'] ) ) {
[738] Fix | Delete
$where_parts[] = $wpdb->prepare( "$column $gt %s", $this->build_mysql_datetime( $query['after'], ! $inclusive ) );
[739] Fix | Delete
}
[740] Fix | Delete
if ( ! empty( $query['before'] ) ) {
[741] Fix | Delete
$where_parts[] = $wpdb->prepare( "$column $lt %s", $this->build_mysql_datetime( $query['before'], $inclusive ) );
[742] Fix | Delete
}
[743] Fix | Delete
// Specific value queries.
[744] Fix | Delete
[745] Fix | Delete
$date_units = array(
[746] Fix | Delete
'YEAR' => array( 'year' ),
[747] Fix | Delete
'MONTH' => array( 'month', 'monthnum' ),
[748] Fix | Delete
'_wp_mysql_week' => array( 'week', 'w' ),
[749] Fix | Delete
'DAYOFYEAR' => array( 'dayofyear' ),
[750] Fix | Delete
'DAYOFMONTH' => array( 'day' ),
[751] Fix | Delete
'DAYOFWEEK' => array( 'dayofweek' ),
[752] Fix | Delete
'WEEKDAY' => array( 'dayofweek_iso' ),
[753] Fix | Delete
);
[754] Fix | Delete
[755] Fix | Delete
// Check of the possible date units and add them to the query.
[756] Fix | Delete
foreach ( $date_units as $sql_part => $query_parts ) {
[757] Fix | Delete
foreach ( $query_parts as $query_part ) {
[758] Fix | Delete
if ( isset( $query[ $query_part ] ) ) {
[759] Fix | Delete
$value = $this->build_value( $compare, $query[ $query_part ] );
[760] Fix | Delete
if ( $value ) {
[761] Fix | Delete
switch ( $sql_part ) {
[762] Fix | Delete
case '_wp_mysql_week':
[763] Fix | Delete
$where_parts[] = _wp_mysql_week( $column ) . " $compare $value";
[764] Fix | Delete
break;
[765] Fix | Delete
case 'WEEKDAY':
[766] Fix | Delete
$where_parts[] = "$sql_part( $column ) + 1 $compare $value";
[767] Fix | Delete
break;
[768] Fix | Delete
default:
[769] Fix | Delete
$where_parts[] = "$sql_part( $column ) $compare $value";
[770] Fix | Delete
}
[771] Fix | Delete
[772] Fix | Delete
break;
[773] Fix | Delete
}
[774] Fix | Delete
}
[775] Fix | Delete
}
[776] Fix | Delete
}
[777] Fix | Delete
[778] Fix | Delete
if ( isset( $query['hour'] ) || isset( $query['minute'] ) || isset( $query['second'] ) ) {
[779] Fix | Delete
// Avoid notices.
[780] Fix | Delete
foreach ( array( 'hour', 'minute', 'second' ) as $unit ) {
[781] Fix | Delete
if ( ! isset( $query[ $unit ] ) ) {
[782] Fix | Delete
$query[ $unit ] = null;
[783] Fix | Delete
}
[784] Fix | Delete
}
[785] Fix | Delete
[786] Fix | Delete
$time_query = $this->build_time_query( $column, $compare, $query['hour'], $query['minute'], $query['second'] );
[787] Fix | Delete
if ( $time_query ) {
[788] Fix | Delete
$where_parts[] = $time_query;
[789] Fix | Delete
}
[790] Fix | Delete
}
[791] Fix | Delete
[792] Fix | Delete
/*
[793] Fix | Delete
* Return an array of 'join' and 'where' for compatibility
[794] Fix | Delete
* with other query classes.
[795] Fix | Delete
*/
[796] Fix | Delete
return array(
[797] Fix | Delete
'where' => $where_parts,
[798] Fix | Delete
'join' => array(),
[799] Fix | Delete
);
[800] Fix | Delete
}
[801] Fix | Delete
[802] Fix | Delete
/**
[803] Fix | Delete
* Builds and validates a value string based on the comparison operator.
[804] Fix | Delete
*
[805] Fix | Delete
* @since 3.7.0
[806] Fix | Delete
*
[807] Fix | Delete
* @param string $compare The compare operator to use.
[808] Fix | Delete
* @param string|array $value The value.
[809] Fix | Delete
* @return string|false|int The value to be used in SQL or false on error.
[810] Fix | Delete
*/
[811] Fix | Delete
public function build_value( $compare, $value ) {
[812] Fix | Delete
if ( ! isset( $value ) ) {
[813] Fix | Delete
return false;
[814] Fix | Delete
}
[815] Fix | Delete
[816] Fix | Delete
switch ( $compare ) {
[817] Fix | Delete
case 'IN':
[818] Fix | Delete
case 'NOT IN':
[819] Fix | Delete
$value = (array) $value;
[820] Fix | Delete
[821] Fix | Delete
// Remove non-numeric values.
[822] Fix | Delete
$value = array_filter( $value, 'is_numeric' );
[823] Fix | Delete
[824] Fix | Delete
if ( empty( $value ) ) {
[825] Fix | Delete
return false;
[826] Fix | Delete
}
[827] Fix | Delete
[828] Fix | Delete
return '(' . implode( ',', array_map( 'intval', $value ) ) . ')';
[829] Fix | Delete
[830] Fix | Delete
case 'BETWEEN':
[831] Fix | Delete
case 'NOT BETWEEN':
[832] Fix | Delete
if ( ! is_array( $value ) || 2 !== count( $value ) ) {
[833] Fix | Delete
$value = array( $value, $value );
[834] Fix | Delete
} else {
[835] Fix | Delete
$value = array_values( $value );
[836] Fix | Delete
}
[837] Fix | Delete
[838] Fix | Delete
// If either value is non-numeric, bail.
[839] Fix | Delete
foreach ( $value as $v ) {
[840] Fix | Delete
if ( ! is_numeric( $v ) ) {
[841] Fix | Delete
return false;
[842] Fix | Delete
}
[843] Fix | Delete
}
[844] Fix | Delete
[845] Fix | Delete
$value = array_map( 'intval', $value );
[846] Fix | Delete
[847] Fix | Delete
return $value[0] . ' AND ' . $value[1];
[848] Fix | Delete
[849] Fix | Delete
default:
[850] Fix | Delete
if ( ! is_numeric( $value ) ) {
[851] Fix | Delete
return false;
[852] Fix | Delete
}
[853] Fix | Delete
[854] Fix | Delete
return (int) $value;
[855] Fix | Delete
}
[856] Fix | Delete
}
[857] Fix | Delete
[858] Fix | Delete
/**
[859] Fix | Delete
* Builds a MySQL format date/time based on some query parameters.
[860] Fix | Delete
*
[861] Fix | Delete
* You can pass an array of values (year, month, etc.) with missing parameter values being defaulted to
[862] Fix | Delete
* either the maximum or minimum values (controlled by the $default_to parameter). Alternatively you can
[863] Fix | Delete
* pass a string that will be passed to date_create().
[864] Fix | Delete
*
[865] Fix | Delete
* @since 3.7.0
[866] Fix | Delete
*
[867] Fix | Delete
* @param string|array $datetime An array of parameters or a strtotime() string.
[868] Fix | Delete
* @param bool $default_to_max Whether to round up incomplete dates. Supported by values
[869] Fix | Delete
* of $datetime that are arrays, or string values that are a
[870] Fix | Delete
* subset of MySQL date format ('Y', 'Y-m', 'Y-m-d', 'Y-m-d H:i').
[871] Fix | Delete
* Default: false.
[872] Fix | Delete
* @return string|false A MySQL format date/time or false on failure.
[873] Fix | Delete
*/
[874] Fix | Delete
public function build_mysql_datetime( $datetime, $default_to_max = false ) {
[875] Fix | Delete
if ( ! is_array( $datetime ) ) {
[876] Fix | Delete
[877] Fix | Delete
/*
[878] Fix | Delete
* Try to parse some common date formats, so we can detect
[879] Fix | Delete
* the level of precision and support the 'inclusive' parameter.
[880] Fix | Delete
*/
[881] Fix | Delete
if ( preg_match( '/^(\d{4})$/', $datetime, $matches ) ) {
[882] Fix | Delete
// Y
[883] Fix | Delete
$datetime = array(
[884] Fix | Delete
'year' => (int) $matches[1],
[885] Fix | Delete
);
[886] Fix | Delete
[887] Fix | Delete
} elseif ( preg_match( '/^(\d{4})\-(\d{2})$/', $datetime, $matches ) ) {
[888] Fix | Delete
// Y-m
[889] Fix | Delete
$datetime = array(
[890] Fix | Delete
'year' => (int) $matches[1],
[891] Fix | Delete
'month' => (int) $matches[2],
[892] Fix | Delete
);
[893] Fix | Delete
[894] Fix | Delete
} elseif ( preg_match( '/^(\d{4})\-(\d{2})\-(\d{2})$/', $datetime, $matches ) ) {
[895] Fix | Delete
// Y-m-d
[896] Fix | Delete
$datetime = array(
[897] Fix | Delete
'year' => (int) $matches[1],
[898] Fix | Delete
'month' => (int) $matches[2],
[899] Fix | Delete
'day' => (int) $matches[3],
[900] Fix | Delete
);
[901] Fix | Delete
[902] Fix | Delete
} elseif ( preg_match( '/^(\d{4})\-(\d{2})\-(\d{2}) (\d{2}):(\d{2})$/', $datetime, $matches ) ) {
[903] Fix | Delete
// Y-m-d H:i
[904] Fix | Delete
$datetime = array(
[905] Fix | Delete
'year' => (int) $matches[1],
[906] Fix | Delete
'month' => (int) $matches[2],
[907] Fix | Delete
'day' => (int) $matches[3],
[908] Fix | Delete
'hour' => (int) $matches[4],
[909] Fix | Delete
'minute' => (int) $matches[5],
[910] Fix | Delete
);
[911] Fix | Delete
}
[912] Fix | Delete
[913] Fix | Delete
// If no match is found, we don't support default_to_max.
[914] Fix | Delete
if ( ! is_array( $datetime ) ) {
[915] Fix | Delete
$wp_timezone = wp_timezone();
[916] Fix | Delete
[917] Fix | Delete
// Assume local timezone if not provided.
[918] Fix | Delete
$dt = date_create( $datetime, $wp_timezone );
[919] Fix | Delete
[920] Fix | Delete
if ( false === $dt ) {
[921] Fix | Delete
return gmdate( 'Y-m-d H:i:s', false );
[922] Fix | Delete
}
[923] Fix | Delete
[924] Fix | Delete
return $dt->setTimezone( $wp_timezone )->format( 'Y-m-d H:i:s' );
[925] Fix | Delete
}
[926] Fix | Delete
}
[927] Fix | Delete
[928] Fix | Delete
$datetime = array_map( 'absint', $datetime );
[929] Fix | Delete
[930] Fix | Delete
if ( ! isset( $datetime['year'] ) ) {
[931] Fix | Delete
$datetime['year'] = current_time( 'Y' );
[932] Fix | Delete
}
[933] Fix | Delete
[934] Fix | Delete
if ( ! isset( $datetime['month'] ) ) {
[935] Fix | Delete
$datetime['month'] = ( $default_to_max ) ? 12 : 1;
[936] Fix | Delete
}
[937] Fix | Delete
[938] Fix | Delete
if ( ! isset( $datetime['day'] ) ) {
[939] Fix | Delete
$datetime['day'] = ( $default_to_max ) ? (int) gmdate( 't', mktime( 0, 0, 0, $datetime['month'], 1, $datetime['year'] ) ) : 1;
[940] Fix | Delete
}
[941] Fix | Delete
[942] Fix | Delete
if ( ! isset( $datetime['hour'] ) ) {
[943] Fix | Delete
$datetime['hour'] = ( $default_to_max ) ? 23 : 0;
[944] Fix | Delete
}
[945] Fix | Delete
[946] Fix | Delete
if ( ! isset( $datetime['minute'] ) ) {
[947] Fix | Delete
$datetime['minute'] = ( $default_to_max ) ? 59 : 0;
[948] Fix | Delete
}
[949] Fix | Delete
[950] Fix | Delete
if ( ! isset( $datetime['second'] ) ) {
[951] Fix | Delete
$datetime['second'] = ( $default_to_max ) ? 59 : 0;
[952] Fix | Delete
}
[953] Fix | Delete
[954] Fix | Delete
return sprintf( '%04d-%02d-%02d %02d:%02d:%02d', $datetime['year'], $datetime['month'], $datetime['day'], $datetime['hour'], $datetime['minute'], $datetime['second'] );
[955] Fix | Delete
}
[956] Fix | Delete
[957] Fix | Delete
/**
[958] Fix | Delete
* Builds a query string for comparing time values (hour, minute, second).
[959] Fix | Delete
*
[960] Fix | Delete
* If just hour, minute, or second is set than a normal comparison will be done.
[961] Fix | Delete
* However if multiple values are passed, a pseudo-decimal time will be created
[962] Fix | Delete
* in order to be able to accurately compare against.
[963] Fix | Delete
*
[964] Fix | Delete
* @since 3.7.0
[965] Fix | Delete
*
[966] Fix | Delete
* @global wpdb $wpdb WordPress database abstraction object.
[967] Fix | Delete
*
[968] Fix | Delete
* @param string $column The column to query against. Needs to be pre-validated!
[969] Fix | Delete
* @param string $compare The comparison operator. Needs to be pre-validated!
[970] Fix | Delete
* @param int|null $hour Optional. An hour value (0-23).
[971] Fix | Delete
* @param int|null $minute Optional. A minute value (0-59).
[972] Fix | Delete
* @param int|null $second Optional. A second value (0-59).
[973] Fix | Delete
* @return string|false A query part or false on failure.
[974] Fix | Delete
*/
[975] Fix | Delete
public function build_time_query( $column, $compare, $hour = null, $minute = null, $second = null ) {
[976] Fix | Delete
global $wpdb;
[977] Fix | Delete
[978] Fix | Delete
// Have to have at least one.
[979] Fix | Delete
if ( ! isset( $hour ) && ! isset( $minute ) && ! isset( $second ) ) {
[980] Fix | Delete
return false;
[981] Fix | Delete
}
[982] Fix | Delete
[983] Fix | Delete
// Complex combined queries aren't supported for multi-value queries.
[984] Fix | Delete
if ( in_array( $compare, array( 'IN', 'NOT IN', 'BETWEEN', 'NOT BETWEEN' ), true ) ) {
[985] Fix | Delete
$return = array();
[986] Fix | Delete
[987] Fix | Delete
$value = $this->build_value( $compare, $hour );
[988] Fix | Delete
if ( false !== $value ) {
[989] Fix | Delete
$return[] = "HOUR( $column ) $compare $value";
[990] Fix | Delete
}
[991] Fix | Delete
[992] Fix | Delete
$value = $this->build_value( $compare, $minute );
[993] Fix | Delete
if ( false !== $value ) {
[994] Fix | Delete
$return[] = "MINUTE( $column ) $compare $value";
[995] Fix | Delete
}
[996] Fix | Delete
[997] Fix | Delete
$value = $this->build_value( $compare, $second );
[998] Fix | Delete
if ( false !== $value ) {
[999] Fix | Delete
It is recommended that you Edit text format, this type of Fix handles quite a lot in one request
Function