. */ require_once(ROOT_DIR . "/helpers/config.php"); /** * PDO wrapper */ class uDb extends PDO { /** * Singleton instance * * @var uDb Object instance */ protected static $instance; /** * Table names * * @var array Array of names */ protected static $tables; /** * Database driver name * * @var string Driver */ protected static $driver; /** * PDO constuctor * * @param string $dsn * @param string $user * @param string $pass */ public function __construct($dsn, $user, $pass) { try { $options = [ PDO::ATTR_EMULATE_PREPARES => false, // try to use native prepared statements PDO::ATTR_ERRMODE => PDO::ERRMODE_EXCEPTION, // throw exceptions PDO::ATTR_DEFAULT_FETCH_MODE => PDO::FETCH_ASSOC, // return assoc array by default ]; @parent::__construct($dsn, $user, $pass, $options); self::$driver = $this->getAttribute(PDO::ATTR_DRIVER_NAME); $this->setCharset("utf8"); $this->initTables(); } catch (PDOException $e) { header("HTTP/1.1 503 Service Unavailable"); die("Database connection error (" . $e->getMessage() . ")"); } } /** * Initialize table names based on config */ private function initTables() { self::$tables = []; $prefix = preg_replace('/[^a-z0-9_]/i', '', uConfig::$dbprefix); self::$tables['positions'] = $prefix . "positions"; self::$tables['tracks'] = $prefix . "tracks"; self::$tables['users'] = $prefix . "users"; } /** * Returns singleton instance * * @return uDb Singleton instance */ public static function getInstance() { if (!self::$instance) { self::$instance = new self(uConfig::$dbdsn, uConfig::$dbuser, uConfig::$dbpass); } return self::$instance; } /** * Get full table name including prefix * * @param string $name Name * @return string Full table name */ public function table($name) { return self::$tables[$name]; } /** * Returns function name for getting date-time column value as unix timestamp * @param string $column * @return string */ public function unix_timestamp($column) { switch (self::$driver) { default: case "mysql": return "UNIX_TIMESTAMP($column)"; break; case "pgsql": return "EXTRACT(EPOCH FROM $column)"; break; case "sqlite": return "STRFTIME('%s', $column)"; break; } } /** * Returns function name for getting date-time column value as 'YYYY-MM-DD hh:mm:ss' * @param string $column * @return string */ public function from_unixtime($column) { switch (self::$driver) { default: case "mysql": return "FROM_UNIXTIME($column)"; break; case "pgsql": return "TO_TIMESTAMP($column)"; break; case "sqlite": return "DATETIME($column, 'unixepoch')"; break; } } /** * Set character set * @param string $charset */ private function setCharset($charset) { if (self::$driver == "pgsql" || self::$driver == "mysql") { $this->query("SET NAMES '$charset'"); } } /** * Extract database name from DSN * @param string $dsn * @return string Empty string if not found */ static public function getDbName($dsn) { $name = ""; if (strpos($dsn, ":") !== false) { list($scheme, $dsnWithoutScheme) = explode(":", $dsn, 2); switch ($scheme) { case "sqlite": case "sqlite2": case "sqlite3": $pattern = "/(.+)/"; break; case "pgsql": $pattern = "/dbname=([^; ]+)/"; break; default: $pattern = "/dbname=([^;]+)/"; break; } $result = preg_match($pattern, $dsnWithoutScheme, $matches); if ($result === 1) { $name = $matches[1]; } } return $name; } } ?>