- Normalizes time difference between WP and database
This commit is contained in:
@@ -26,6 +26,7 @@ class Env {
|
|||||||
static $db_username;
|
static $db_username;
|
||||||
static $db_password;
|
static $db_password;
|
||||||
static $db_charset;
|
static $db_charset;
|
||||||
|
static $db_timezone_offset;
|
||||||
|
|
||||||
static function init($file, $version) {
|
static function init($file, $version) {
|
||||||
global $wpdb;
|
global $wpdb;
|
||||||
@@ -58,6 +59,7 @@ class Env {
|
|||||||
self::$db_password = DB_PASSWORD;
|
self::$db_password = DB_PASSWORD;
|
||||||
self::$db_charset = $wpdb->get_charset_collate();
|
self::$db_charset = $wpdb->get_charset_collate();
|
||||||
self::$db_source_name = self::dbSourceName(self::$db_host, self::$db_socket, self::$db_port);
|
self::$db_source_name = self::dbSourceName(self::$db_host, self::$db_socket, self::$db_port);
|
||||||
|
self::$db_timezone_offset = self::getDbTimezoneOffset();
|
||||||
}
|
}
|
||||||
|
|
||||||
private static function dbSourceName($host, $socket, $port) {
|
private static function dbSourceName($host, $socket, $port) {
|
||||||
@@ -73,4 +75,13 @@ class Env {
|
|||||||
);
|
);
|
||||||
return implode('', $source_name);
|
return implode('', $source_name);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
private static function getDbTimezoneOffset() {
|
||||||
|
$mins = get_option('gmt_offset') * 60;
|
||||||
|
$sgn = ($mins < 0 ? -1 : 1);
|
||||||
|
$mins = abs($mins);
|
||||||
|
$hrs = floor($mins / 60);
|
||||||
|
$mins -= $hrs * 60;
|
||||||
|
return sprintf('%+d:%02d', $hrs * $sgn, $mins);
|
||||||
|
}
|
||||||
}
|
}
|
@@ -65,7 +65,8 @@ class Initializer {
|
|||||||
|
|
||||||
\ORM::configure('driver_options', array(
|
\ORM::configure('driver_options', array(
|
||||||
\PDO::MYSQL_ATTR_INIT_COMMAND => 'SET NAMES utf8',
|
\PDO::MYSQL_ATTR_INIT_COMMAND => 'SET NAMES utf8',
|
||||||
\PDO::MYSQL_ATTR_INIT_COMMAND => 'SET TIME_ZONE = "+00:00"'
|
\PDO::MYSQL_ATTR_INIT_COMMAND =>
|
||||||
|
'SET TIME_ZONE = "' . Env::$db_timezone_offset. '"'
|
||||||
));
|
));
|
||||||
|
|
||||||
$subscribers = Env::$db_prefix . 'subscribers';
|
$subscribers = Env::$db_prefix . 'subscribers';
|
||||||
|
Reference in New Issue
Block a user