]>
git.wh0rd.org - tt-rss.git/blob - classes/db.php
2 class Db
implements IDb
{
4 /* @var Db $instance */
5 private static $instance;
7 /* @var IDb $adapter */
15 private function __construct() {
19 private function __clone() {
23 private function legacy_connect() {
25 user_error("Legacy connect requested to " . DB_TYPE
, E_USER_NOTICE
);
27 $er = error_reporting(E_ALL
);
31 $this->adapter
= new Db_Mysqli();
34 $this->adapter
= new Db_Pgsql();
37 die("Unknown DB_TYPE: " . DB_TYPE
);
40 if (!$this->adapter
) {
41 print("Error initializing database adapter for " . DB_TYPE
);
45 $this->link
= $this->adapter
->connect(DB_HOST
, DB_USER
, DB_PASS
, DB_NAME
, defined('DB_PORT') ? DB_PORT
: "");
48 print("Error connecting through adapter: " . $this->adapter
->last_error());
55 private function pdo_connect() {
57 $db_port = defined('DB_PORT') && DB_PORT ?
';port='.DB_PORT
: '';
59 $this->pdo
= new PDO(DB_TYPE
. ':dbname='.DB_NAME
.';host='.DB_HOST
.$db_port,
64 print("Error connecting via PDO.");
68 $this->pdo
->setAttribute( PDO
::ATTR_ERRMODE
, PDO
::ERRMODE_WARNING
);
70 if (DB_TYPE
== "pgsql") {
72 $this->pdo
->query("set client_encoding = 'UTF-8'");
73 $this->pdo
->query("set datestyle = 'ISO, european'");
74 $this->pdo
->query("set TIME ZONE 0");
75 $this->pdo
->query("set cpu_tuple_cost = 0.5");
77 } else if (DB_TYPE
== "mysql") {
78 $this->pdo
->query("SET time_zone = '+0:0'");
80 if (defined('MYSQL_CHARSET') && MYSQL_CHARSET
) {
81 $this->pdo
->query("SET NAMES " . MYSQL_CHARSET
);
86 public static function get() {
87 if (self
::$instance == null)
88 self
::$instance = new self();
90 if (!self
::$instance->link
) {
91 self
::$instance->legacy_connect();
94 return self
::$instance;
97 public static function pdo() {
98 if (self
::$instance == null)
99 self
::$instance = new self();
101 if (!self
::$instance->pdo
) {
102 self
::$instance->pdo_connect();
105 return self
::$instance->pdo
;
108 static function quote($str){
112 function reconnect() {
113 $this->link
= $this->adapter
->connect(DB_HOST
, DB_USER
, DB_PASS
, DB_NAME
, defined('DB_PORT') ? DB_PORT
: "");
116 function connect($host, $user, $pass, $db, $port) {
117 //return $this->adapter->connect($host, $user, $pass, $db, $port);
121 function escape_string($s, $strip_tags = true) {
122 return $this->adapter
->escape_string($s, $strip_tags);
125 function query($query, $die_on_error = true) {
126 return $this->adapter
->query($query, $die_on_error);
129 function fetch_assoc($result) {
130 return $this->adapter
->fetch_assoc($result);
133 function num_rows($result) {
134 return $this->adapter
->num_rows($result);
137 function fetch_result($result, $row, $param) {
138 return $this->adapter
->fetch_result($result, $row, $param);
142 return $this->adapter
->close();
145 function affected_rows($result) {
146 return $this->adapter
->affected_rows($result);
149 function last_error() {
150 return $this->adapter
->last_error();
153 function last_query_error() {
154 return $this->adapter
->last_query_error();