From f38be747d132d754801c46ee3df15f8c27a03762 Mon Sep 17 00:00:00 2001 From: Andrew Dolgov Date: Mon, 1 Mar 2021 18:36:47 +0300 Subject: initial for idiorm --- classes/db.php | 29 ++++++++++++++++++++--------- 1 file changed, 20 insertions(+), 9 deletions(-) (limited to 'classes/db.php') diff --git a/classes/db.php b/classes/db.php index a760d4402..a30ffad31 100755 --- a/classes/db.php +++ b/classes/db.php @@ -1,27 +1,38 @@ prepare(...) etc - public function pdo_connect() { - + public static function get_dsn() { $db_port = Config::get(Config::DB_PORT) ? ';port=' . Config::get(Config::DB_PORT) : ''; $db_host = Config::get(Config::DB_HOST) ? ';host=' . Config::get(Config::DB_HOST) : ''; + return Config::get(Config::DB_TYPE) . ':dbname=' . Config::get(Config::DB_NAME) . $db_host . $db_port; + } + + // this really shouldn't be used unless a separate PDO connection is needed + // normal usage is Db::pdo()->prepare(...) etc + public function pdo_connect() : PDO { + try { - $pdo = new PDO(Config::get(Config::DB_TYPE) . ':dbname=' . Config::get(Config::DB_NAME) . $db_host . $db_port, + $pdo = new PDO(self::get_dsn(), Config::get(Config::DB_USER), Config::get(Config::DB_PASS)); } catch (Exception $e) { @@ -49,7 +60,7 @@ class Db return $pdo; } - public static function instance() { + public static function instance() : Db { if (self::$instance == null) self::$instance = new self(); @@ -60,7 +71,7 @@ class Db if (self::$instance == null) self::$instance = new self(); - if (!self::$instance->pdo) { + if (empty(self::$instance->pdo)) { self::$instance->pdo = self::$instance->pdo_connect(); } -- cgit v1.2.3