]>
git.wh0rd.org - tt-rss.git/blob - classes/db.php
5 /* @var Db $instance */
6 private static $instance;
8 /* @var IDb $adapter */
16 private function __clone() {
20 private function legacy_connect() {
22 user_error("Legacy connect requested to " . DB_TYPE
, E_USER_NOTICE
);
24 $er = error_reporting(E_ALL
);
28 $this->adapter
= new Db_Mysqli();
31 $this->adapter
= new Db_Pgsql();
34 die("Unknown DB_TYPE: " . DB_TYPE
);
37 if (!$this->adapter
) {
38 print("Error initializing database adapter for " . DB_TYPE
);
42 $this->link
= $this->adapter
->connect(DB_HOST
, DB_USER
, DB_PASS
, DB_NAME
, defined('DB_PORT') ? DB_PORT
: "");
45 print("Error connecting through adapter: " . $this->adapter
->last_error());
52 private function pdo_connect() {
54 $db_port = defined('DB_PORT') && DB_PORT ?
';port=' . DB_PORT
: '';
55 $db_host = defined('DB_HOST') && DB_HOST ?
';host=' . DB_HOST
: '';
58 $this->pdo
= new PDO(DB_TYPE
. ':dbname=' . DB_NAME
. $db_host . $db_port,
61 } catch (Exception
$e) {
62 print "<pre>Exception while creating PDO object:" . $e->getMessage() . "</pre>";
66 $this->pdo
->setAttribute(PDO
::ATTR_ERRMODE
, PDO
::ERRMODE_WARNING
);
68 if (DB_TYPE
== "pgsql") {
70 $this->pdo
->query("set client_encoding = 'UTF-8'");
71 $this->pdo
->query("set datestyle = 'ISO, european'");
72 $this->pdo
->query("set TIME ZONE 0");
73 $this->pdo
->query("set cpu_tuple_cost = 0.5");
75 } else if (DB_TYPE
== "mysql") {
76 $this->pdo
->query("SET time_zone = '+0:0'");
78 if (defined('MYSQL_CHARSET') && MYSQL_CHARSET
) {
79 $this->pdo
->query("SET NAMES " . MYSQL_CHARSET
);
84 public static function get() {
85 if (self
::$instance == null)
86 self
::$instance = new self();
88 if (!self
::$instance->adapter
) {
89 self
::$instance->legacy_connect();
92 return self
::$instance->adapter
;
95 public static function pdo() {
96 if (self
::$instance == null)
97 self
::$instance = new self();
99 if (!self
::$instance->pdo
) {
100 self
::$instance->pdo_connect();
103 return self
::$instance->pdo
;