mirror of
https://github.com/kremalicious/krtmn.git
synced 2025-01-03 10:25:04 +01:00
313 lines
7.7 KiB
PHP
313 lines
7.7 KiB
PHP
|
<?php
|
||
|
|
||
|
/**********************************************************************
|
||
|
* Author: Justin Vincent (jv@jvmultimedia.com)
|
||
|
* Web...: http://twitter.com/justinvincent
|
||
|
* Name..: ezSQL_pdo
|
||
|
* Desc..: PDO component (part of ezSQL databse abstraction library)
|
||
|
*
|
||
|
*/
|
||
|
|
||
|
/**********************************************************************
|
||
|
* ezSQL error strings - PDO
|
||
|
*/
|
||
|
|
||
|
global $ezsql_pdo_str;
|
||
|
|
||
|
$ezsql_pdo_str = array
|
||
|
(
|
||
|
1 => 'Require $dsn and $user and $password to create a connection'
|
||
|
);
|
||
|
|
||
|
/**********************************************************************
|
||
|
* ezSQL Database specific class - PDO
|
||
|
*/
|
||
|
|
||
|
if ( ! class_exists ('PDO') ) die('<b>Fatal Error:</b> ezSQL_pdo requires PDO Lib to be compiled and or linked in to the PHP engine');
|
||
|
if ( ! class_exists ('ezSQLcore') ) die('<b>Fatal Error:</b> ezSQL_pdo requires ezSQLcore (ez_sql_core.php) to be included/loaded before it can be used');
|
||
|
|
||
|
class ezSQL_pdo extends ezSQLcore
|
||
|
{
|
||
|
|
||
|
var $dsn;
|
||
|
var $user;
|
||
|
var $password;
|
||
|
var $rows_affected = false;
|
||
|
|
||
|
/**********************************************************************
|
||
|
* Constructor - allow the user to perform a qucik connect at the
|
||
|
* same time as initialising the ezSQL_pdo class
|
||
|
*/
|
||
|
|
||
|
function __construct($dsn='', $user='', $password='', $ssl=array())
|
||
|
{
|
||
|
// Turn on track errors
|
||
|
ini_set('track_errors',1);
|
||
|
|
||
|
if ( $dsn && $user )
|
||
|
{
|
||
|
$this->connect($dsn, $user, $password);
|
||
|
}
|
||
|
}
|
||
|
|
||
|
/**********************************************************************
|
||
|
* Try to connect to database server
|
||
|
*/
|
||
|
|
||
|
function connect($dsn='', $user='', $password='', $ssl=array())
|
||
|
{
|
||
|
global $ezsql_pdo_str; $return_val = false;
|
||
|
|
||
|
// Must have a dsn and user
|
||
|
if ( ! $dsn || ! $user )
|
||
|
{
|
||
|
$this->register_error($ezsql_pdo_str[1].' in '.__FILE__.' on line '.__LINE__);
|
||
|
$this->show_errors ? trigger_error($ezsql_pdo_str[1],E_USER_WARNING) : null;
|
||
|
}
|
||
|
|
||
|
// Establish PDO connection
|
||
|
try
|
||
|
{
|
||
|
if(!empty($ssl))
|
||
|
{
|
||
|
$this->dbh = new PDO($dsn, $user, $password, $ssl);
|
||
|
}
|
||
|
else
|
||
|
{
|
||
|
$this->dbh = new PDO($dsn, $user, $password);
|
||
|
}
|
||
|
|
||
|
$return_val = true;
|
||
|
}
|
||
|
catch (PDOException $e)
|
||
|
{
|
||
|
$this->register_error($e->getMessage());
|
||
|
$this->show_errors ? trigger_error($e->getMessage(),E_USER_WARNING) : null;
|
||
|
}
|
||
|
|
||
|
return $return_val;
|
||
|
}
|
||
|
|
||
|
/**********************************************************************
|
||
|
* In the case of PDO quick_connect is not really needed
|
||
|
* because std. connect already does what quick connect does -
|
||
|
* but for the sake of consistency it has been included
|
||
|
*/
|
||
|
|
||
|
function quick_connect($dsn='', $user='', $password='', $ssl=array())
|
||
|
{
|
||
|
return $this->connect($dsn, $user, $password);
|
||
|
}
|
||
|
|
||
|
/**********************************************************************
|
||
|
* No real equivalent of mySQL select in PDO
|
||
|
* once again, function included for the sake of consistency
|
||
|
*/
|
||
|
|
||
|
function select($dsn='', $user='', $password='', $ssl=array())
|
||
|
{
|
||
|
return $this->connect($dsn, $user, $password);
|
||
|
}
|
||
|
|
||
|
/**********************************************************************
|
||
|
* Format a string correctly for safe PDO insert
|
||
|
* (no mater if magic quotes are on or not)
|
||
|
*/
|
||
|
|
||
|
function escape($str)
|
||
|
{
|
||
|
switch (gettype($str))
|
||
|
{
|
||
|
case 'string' : $str = addslashes(stripslashes($str));
|
||
|
break;
|
||
|
case 'boolean' : $str = ($str === FALSE) ? 0 : 1;
|
||
|
break;
|
||
|
default : $str = ($str === NULL) ? 'NULL' : $str;
|
||
|
break;
|
||
|
}
|
||
|
|
||
|
return $str;
|
||
|
}
|
||
|
|
||
|
/**********************************************************************
|
||
|
* Return specific system date syntax
|
||
|
* i.e. Oracle: SYSDATE Mysql: NOW()
|
||
|
*/
|
||
|
|
||
|
function sysdate()
|
||
|
{
|
||
|
return "NOW()";
|
||
|
}
|
||
|
|
||
|
/**********************************************************************
|
||
|
* Hooks into PDO error system and reports it to user
|
||
|
*/
|
||
|
|
||
|
function catch_error()
|
||
|
{
|
||
|
$error_str = 'No error info';
|
||
|
|
||
|
$err_array = $this->dbh->errorInfo();
|
||
|
|
||
|
// Note: Ignoring error - bind or column index out of range
|
||
|
if ( isset($err_array[1]) && $err_array[1] != 25)
|
||
|
{
|
||
|
|
||
|
$error_str = '';
|
||
|
foreach ( $err_array as $entry )
|
||
|
{
|
||
|
$error_str .= $entry . ', ';
|
||
|
}
|
||
|
|
||
|
$error_str = substr($error_str,0,-2);
|
||
|
|
||
|
$this->register_error($error_str);
|
||
|
$this->show_errors ? trigger_error($error_str.' '.$this->last_query,E_USER_WARNING) : null;
|
||
|
|
||
|
return true;
|
||
|
}
|
||
|
|
||
|
}
|
||
|
|
||
|
// ==================================================================
|
||
|
// Basic Query - see docs for more detail
|
||
|
|
||
|
function query($query)
|
||
|
{
|
||
|
|
||
|
// For reg expressions
|
||
|
$query = str_replace("/[\n\r]/",'',trim($query));
|
||
|
|
||
|
// initialise return
|
||
|
$return_val = 0;
|
||
|
|
||
|
// Flush cached values..
|
||
|
$this->flush();
|
||
|
|
||
|
// Log how the function was called
|
||
|
$this->func_call = "\$db->query(\"$query\")";
|
||
|
|
||
|
// Keep track of the last query for debug..
|
||
|
$this->last_query = $query;
|
||
|
|
||
|
$this->num_queries++;
|
||
|
|
||
|
// Start timer
|
||
|
$this->timer_start($this->num_queries);
|
||
|
|
||
|
// Use core file cache function
|
||
|
if ( $cache = $this->get_cache($query) )
|
||
|
{
|
||
|
|
||
|
// Keep tack of how long all queries have taken
|
||
|
$this->timer_update_global($this->num_queries);
|
||
|
|
||
|
// Trace all queries
|
||
|
if ( $this->use_trace_log )
|
||
|
{
|
||
|
$this->trace_log[] = $this->debug(false);
|
||
|
}
|
||
|
|
||
|
return $cache;
|
||
|
}
|
||
|
|
||
|
// If there is no existing database connection then try to connect
|
||
|
if ( ! isset($this->dbh) || ! $this->dbh )
|
||
|
{
|
||
|
$this->connect($this->dsn, $this->user, $this->password);
|
||
|
if ( ! isset($this->dbh) || ! $this->dbh )
|
||
|
return false;
|
||
|
}
|
||
|
|
||
|
// Query was an insert, delete, update, replace
|
||
|
if ( preg_match("/^(insert|delete|update|replace|drop|create)\s+/i",$query) )
|
||
|
{
|
||
|
|
||
|
// Perform the query and log number of affected rows
|
||
|
$this->rows_affected = $this->dbh->exec($query);
|
||
|
|
||
|
// If there is an error then take note of it..
|
||
|
if ( $this->catch_error() ) return false;
|
||
|
|
||
|
$is_insert = true;
|
||
|
|
||
|
// Take note of the insert_id
|
||
|
if ( preg_match("/^(insert|replace)\s+/i",$query) )
|
||
|
{
|
||
|
$this->insert_id = @$this->dbh->lastInsertId();
|
||
|
}
|
||
|
|
||
|
// Return number fo rows affected
|
||
|
$return_val = $this->rows_affected;
|
||
|
|
||
|
}
|
||
|
// Query was an select
|
||
|
else
|
||
|
{
|
||
|
|
||
|
// Perform the query and log number of affected rows
|
||
|
$sth = $this->dbh->query($query);
|
||
|
|
||
|
// If there is an error then take note of it..
|
||
|
if ( $this->catch_error() ) return false;
|
||
|
|
||
|
$is_insert = false;
|
||
|
|
||
|
$col_count = $sth->columnCount();
|
||
|
|
||
|
for ( $i=0 ; $i < $col_count ; $i++ )
|
||
|
{
|
||
|
$this->col_info[$i] = new stdClass();
|
||
|
|
||
|
if ( $meta = $sth->getColumnMeta($i) )
|
||
|
{
|
||
|
$this->col_info[$i]->name = $meta['name'];
|
||
|
$this->col_info[$i]->type = !empty($meta['native_type']) ? $meta['native_type'] : 'undefined';
|
||
|
$this->col_info[$i]->max_length = '';
|
||
|
}
|
||
|
else
|
||
|
{
|
||
|
$this->col_info[$i]->name = 'undefined';
|
||
|
$this->col_info[$i]->type = 'undefined';
|
||
|
$this->col_info[$i]->max_length = '';
|
||
|
}
|
||
|
}
|
||
|
|
||
|
// Store Query Results
|
||
|
$num_rows=0;
|
||
|
while ( $row = @$sth->fetch(PDO::FETCH_ASSOC) )
|
||
|
{
|
||
|
// Store relults as an objects within main array
|
||
|
$this->last_result[$num_rows] = (object) $row;
|
||
|
$num_rows++;
|
||
|
}
|
||
|
|
||
|
// Log number of rows the query returned
|
||
|
$this->num_rows = $num_rows;
|
||
|
|
||
|
// Return number of rows selected
|
||
|
$return_val = $this->num_rows;
|
||
|
|
||
|
}
|
||
|
|
||
|
// disk caching of queries
|
||
|
$this->store_cache($query,$is_insert);
|
||
|
|
||
|
// If debug ALL queries
|
||
|
$this->trace || $this->debug_all ? $this->debug() : null ;
|
||
|
|
||
|
// Keep tack of how long all queries have taken
|
||
|
$this->timer_update_global($this->num_queries);
|
||
|
|
||
|
// Trace all queries
|
||
|
if ( $this->use_trace_log )
|
||
|
{
|
||
|
$this->trace_log[] = $this->debug(false);
|
||
|
}
|
||
|
|
||
|
return $return_val;
|
||
|
|
||
|
}
|
||
|
|
||
|
}
|