wpseek.com
A WordPress-centric search engine for devs and theme authors



iso8601_to_datetime › WordPress Function

Since1.5.0
Deprecatedn/a
iso8601_to_datetime ( $date_string, $timezone = 'user' )
Parameters: (2)
  • (string) $date_string Date and time in ISO 8601 format {@link}.
    Required: Yes
  • (string) $timezone Optional. If set to 'gmt' returns the result in UTC. Default 'user'.
    Required: No
    Default: 'user'
Returns:
  • (string|false) The date and time in MySQL DateTime format - Y-m-d H:i:s, or false on failure.
Defined at:
Codex:

Given an ISO 8601 (Ymd\TH:i:sO) date, returns a MySQL DateTime (Y-m-d H:i:s) format used by post_date[_gmt].



Source

function iso8601_to_datetime( $date_string, $timezone = 'user' ) {
	$timezone    = strtolower( $timezone );
	$wp_timezone = wp_timezone();
	$datetime    = date_create( $date_string, $wp_timezone ); // Timezone is ignored if input has one.

	if ( false === $datetime ) {
		return false;
	}

	if ( 'gmt' === $timezone ) {
		return $datetime->setTimezone( new DateTimeZone( 'UTC' ) )->format( 'Y-m-d H:i:s' );
	}

	if ( 'user' === $timezone ) {
		return $datetime->setTimezone( $wp_timezone )->format( 'Y-m-d H:i:s' );
	}

	return false;
}