2010-12-18 01:18:03 +11:00
|
|
|
<?php
|
|
|
|
|
|
|
|
function sql_open() {
|
2011-02-12 17:25:15 +11:00
|
|
|
global $pdo, $config;
|
2010-12-18 01:18:03 +11:00
|
|
|
if($pdo) return true;
|
|
|
|
|
2011-02-12 17:25:15 +11:00
|
|
|
$dsn = $config['db']['type'] . ':host=' . $config['db']['server'] . ';dbname=' . $config['db']['database'];
|
|
|
|
if(!empty($config['db']['dsn']))
|
|
|
|
$dsn .= ';' . $config['db']['dsn'];
|
2010-12-18 01:18:03 +11:00
|
|
|
try {
|
2011-02-12 17:25:15 +11:00
|
|
|
return $pdo = new PDO($dsn, $config['db']['user'], $config['db']['password']);
|
2010-12-18 01:18:03 +11:00
|
|
|
} catch(PDOException $e) {
|
2010-12-18 01:32:12 +11:00
|
|
|
$message = $e->getMessage();
|
|
|
|
|
|
|
|
// Remove any sensitive information
|
2011-02-12 17:25:15 +11:00
|
|
|
$message = str_replace($config['db']['user'], '<em>hidden</em>', $message);
|
|
|
|
$message = str_replace($config['db']['password'], '<em>hidden</em>', $message);
|
2010-12-18 01:32:12 +11:00
|
|
|
|
|
|
|
// Print error
|
|
|
|
error('Database error: ' . $message);
|
2010-12-18 01:18:03 +11:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
function sql_close() {
|
|
|
|
global $pdo;
|
|
|
|
$pdo = NULL;
|
|
|
|
}
|
|
|
|
|
|
|
|
function prepare($query) {
|
|
|
|
global $pdo;
|
|
|
|
return $pdo->prepare($query);
|
|
|
|
}
|
|
|
|
|
|
|
|
function query($query) {
|
|
|
|
global $pdo;
|
|
|
|
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];
|
|
|
|
}
|
|
|
|
}
|
|
|
|
?>
|