1
0
mirror of https://github.com/vichan-devel/vichan.git synced 2024-11-14 19:07:39 +01:00
vichan/inc/database.php

68 lines
1.6 KiB
PHP
Raw Normal View History

2010-12-17 15:18:03 +01:00
<?php
2011-04-13 14:21:07 +02:00
if($_SERVER['SCRIPT_FILENAME'] == str_replace('\\', '/', __FILE__)) {
// You cannot request this file directly.
header('Location: ../', true, 302);
exit;
}
2010-12-17 15:18:03 +01:00
function sql_open() {
2011-02-12 07:25:15 +01:00
global $pdo, $config;
2010-12-17 15:18:03 +01:00
if($pdo) return true;
2011-02-12 07:25:15 +01:00
$dsn = $config['db']['type'] . ':host=' . $config['db']['server'] . ';dbname=' . $config['db']['database'];
if(!empty($config['db']['dsn']))
$dsn .= ';' . $config['db']['dsn'];
2010-12-17 15:18:03 +01:00
try {
$options = Array(PDO::ATTR_TIMEOUT => $config['db']['timeout']);
if($config['db']['persistent'])
$options[PDO::ATTR_PERSISTENT] = true;
2011-02-12 07:25:15 +01:00
return $pdo = new PDO($dsn, $config['db']['user'], $config['db']['password']);
2010-12-17 15:18:03 +01:00
} catch(PDOException $e) {
$message = $e->getMessage();
// Remove any sensitive information
2011-02-12 07:25:15 +01:00
$message = str_replace($config['db']['user'], '<em>hidden</em>', $message);
$message = str_replace($config['db']['password'], '<em>hidden</em>', $message);
// Print error
error('Database error: ' . $message);
2010-12-17 15:18:03 +01:00
}
}
function sql_close() {
global $pdo, $config;
if(!$config['db']['persistent'])
$pdo = NULL;
2010-12-17 15:18:03 +01:00
}
function prepare($query) {
2011-05-21 07:22:10 +02:00
global $pdo, $debug, $config;
if($config['debug']) {
$debug['sql'][] = $query;
}
sql_open();
2010-12-17 15:18:03 +01:00
return $pdo->prepare($query);
}
function query($query) {
2011-05-21 07:22:10 +02:00
global $pdo, $debug, $config;
if($config['debug']) {
$debug['sql'][] = $query;
}
sql_open();
2010-12-17 15:18:03 +01:00
return $pdo->query($query);
}
function db_error($PDOStatement=null) {
global $pdo;
if(isset($PDOStatement)) {
$err = $PDOStatement->errorInfo();
return $err[2];
} else {
$err = $pdo->errorInfo();
return $err[2];
}
}
?>