wp_resolve_post_date()
Uses wp_checkdate to return a valid Gregorian-calendar value for post_date. If post_date is not provided, this first checks post_date_gmt if provided, then falls back to use the current time.
For back-compat purposes in wp_insert_post, an empty post_date and an invalid post_date_gmt will continue to return '1970-01-01 00:00:00' rather than false.
No Hooks.
Returns
String|false. A valid Gregorian-calendar date string, or false on failure.
Usage
wp_resolve_post_date( $post_date, $post_date_gmt );
- $post_date(string)
- The date in mysql format (
Y-m-d H:i:s).
Default:'' - $post_date_gmt(string)
- The GMT date in mysql format (
Y-m-d H:i:s).
Default:''
Changelog
| Since 5.7.0 | Introduced. |
wp_resolve_post_date() wp resolve post date code WP 6.9.1
function wp_resolve_post_date( $post_date = '', $post_date_gmt = '' ) {
// If the date is empty, set the date to now.
if ( empty( $post_date ) || '0000-00-00 00:00:00' === $post_date ) {
if ( empty( $post_date_gmt ) || '0000-00-00 00:00:00' === $post_date_gmt ) {
$post_date = current_time( 'mysql' );
} else {
$post_date = get_date_from_gmt( $post_date_gmt );
}
}
// Validate the date.
preg_match( '/^(\d{4})-(\d{1,2})-(\d{1,2})/', $post_date, $matches );
if ( empty( $matches ) || ! is_array( $matches ) || count( $matches ) < 4 ) {
return false;
}
$valid_date = wp_checkdate( $matches[2], $matches[3], $matches[1], $post_date );
if ( ! $valid_date ) {
return false;
}
return $post_date;
}