getAuthUser()) { $this->jerr("Not authenticated", array('authFailure' => true)); } return true; } function get($base, $opts=array()) { self::getOffsets(); $data = array(); foreach(self::$offsets as $tz => $o) { $arr = explode('/', $tz); $data[] = array( 'region' => $arr[0], 'area' => $arr[1], 'offset' => $o, 'displayArea' => self::getDisplayArea($tz) ); } echo json_encode(array( 'data' => $data, 'metaData' => array( 'id' => 'id', 'root' => 'data', 'successProperty' => 'success', 'totalProperty' => 'total', 'fields' => array( 'id', 'region', 'area', 'offset', 'dipslayArea' ) ), 'success' => true, 'total' => count($data), )); exit; } function post($base) { die('Invalid post'); } static $offsets = array(); static function getOffsets() { if(!empty(self::$offsets)) { return self::$offsets; } $ce = DB_DataObject::factory('core_enum'); $ce->query(' SELECT *, TIME_FORMAT(TIMEDIFF(NOW(), CONVERT_TZ(NOW(), Name, "UTC")), "%H:%i") as offset FROM mysql.time_zone_name ORDER BY offset DESC, Name DESC '); while($ce->fetch()) { // ignroe timezone such as 'CET' and 'America/Argentina/Buenos_Aires' if(substr_count($ce->Name, '/') != 1) { continue; } $ar = explode('/', $ce->Name); // ignore timezone such as 'Etc/GMT+8' if($ar[0] == 'Etc') { continue; } self::$offsets[$ce->Name] = substr($ce->offset, 0, 1) == '-' ? $ce->offset : '+' . $ce->offset; } return self::$offsets; } static function getDisplayArea($timezone) { self::getOffsets(); // invalid timezone if(!isset(self::$offsets[$timezone])) { return ''; } $ar = explode('/', $timezone); // e.g. 'Hong_Kong (GMT +08:00)' return $ar[1] . ' (GMT ' . self::$offsets[$timezone] . ')'; } }