2003-05-28 10:41:04 +02:00
< ? php
2004-04-26 04:54:06 +02:00
// WordPress DB Class
// ORIGINAL CODE FROM:
// Justin Vincent (justin@visunet.ie)
// http://php.justinvincent.com
2004-04-26 04:28:06 +02:00
2004-04-26 04:54:06 +02:00
define ( 'EZSQL_VERSION' , 'WP1.25' );
define ( 'OBJECT' , 'OBJECT' , true );
define ( 'ARRAY_A' , 'ARRAY_A' , false );
define ( 'ARRAY_N' , 'ARRAY_N' , false );
2004-08-20 19:52:49 +02:00
2004-04-26 04:54:06 +02:00
if ( ! defined ( 'SAVEQUERIES' ))
define ( 'SAVEQUERIES' , false );
2004-04-26 04:28:06 +02:00
class wpdb {
var $show_errors = true ;
2004-04-26 04:54:06 +02:00
var $num_queries = 0 ;
var $last_query ;
var $col_info ;
2004-08-20 19:52:49 +02:00
var $queries ;
2003-05-28 10:41:04 +02:00
2004-05-24 10:22:18 +02:00
// Our tables
var $posts ;
var $users ;
var $categories ;
var $post2cat ;
var $comments ;
var $links ;
var $linkcategories ;
var $options ;
var $optiontypes ;
var $optionvalues ;
var $optiongroups ;
var $optiongroup_options ;
var $postmeta ;
2004-04-26 04:28:06 +02:00
// ==================================================================
// DB Constructor - connects to the server and selects a database
function wpdb ( $dbuser , $dbpassword , $dbname , $dbhost ) {
2007-01-30 19:33:48 +01:00
return $this -> __construct ( $dbuser , $dbpassword , $dbname , $dbhost );
}
function __construct ( $dbuser , $dbpassword , $dbname , $dbhost ) {
register_shutdown_function ( array ( & $this , " __destruct " ));
2004-08-20 19:52:49 +02:00
$this -> dbh = @ mysql_connect ( $dbhost , $dbuser , $dbpassword );
2004-04-26 04:54:06 +02:00
if ( ! $this -> dbh ) {
2004-07-23 03:35:56 +02:00
$this -> bail ( "
< h1 > Error establishing a database connection </ h1 >
2005-04-19 05:25:14 +02:00
< p > This either means that the username and password information in your < code > wp - config . php </ code > file is incorrect or we can 't contact the database server at <code>$dbhost</code>. This could mean your host' s database server is down .</ p >
2004-07-23 03:35:56 +02:00
< ul >
< li > Are you sure you have the correct username and password ? </ li >
< li > Are you sure that you have typed the correct hostname ? </ li >
< li > Are you sure that the database server is running ? </ li >
</ ul >
< p > If you 're unsure what these terms mean you should probably contact your host. If you still need help you can always visit the <a href=' http :// wordpress . org / support / ' > WordPress Support Forums </ a >.</ p >
" );
2003-05-28 10:41:04 +02:00
}
2004-04-26 04:28:06 +02:00
$this -> select ( $dbname );
}
2003-05-28 10:41:04 +02:00
2007-01-30 19:33:48 +01:00
function __destruct () {
return true ;
}
2004-04-26 04:28:06 +02:00
// ==================================================================
// Select a DB (if another one needs to be selected)
function select ( $db ) {
2004-08-20 19:52:49 +02:00
if ( !@ mysql_select_db ( $db , $this -> dbh )) {
2004-07-23 03:35:56 +02:00
$this -> bail ( "
< h1 > Can & #8217;t select database</h1>
< p > We were able to connect to the database server ( which means your username and password is okay ) but not able to select the < code > $db </ code > database .</ p >
< ul >
< li > Are you sure it exists ? </ li >
< li > On some systems the name of your database is prefixed with your username , so it would be like username_wordpress . Could that be the problem ? </ li >
</ ul >
2005-04-19 05:25:14 +02:00
< p > If you don 't know how to setup a database you should <strong>contact your host</strong>. If all else fails you may find help at the <a href=' http :// wordpress . org / support / ' > WordPress Support Forums </ a >.</ p > " );
2003-05-28 10:41:04 +02:00
}
2004-04-26 04:28:06 +02:00
}
2003-05-28 10:41:04 +02:00
2004-04-26 04:28:06 +02:00
// ====================================================================
// Format a string correctly for safe insert under all PHP conditions
2005-07-04 08:27:04 +02:00
function escape ( $string ) {
2005-07-26 22:11:41 +02:00
return addslashes ( $string ); // Disable rest for now, causing problems
2005-07-03 01:31:43 +02:00
if ( ! $this -> dbh || version_compare ( phpversion (), '4.3.0' ) == '-1' )
return mysql_escape_string ( $string );
else
return mysql_real_escape_string ( $string , $this -> dbh );
2004-04-26 04:28:06 +02:00
}
2003-05-28 10:41:04 +02:00
2004-04-26 04:28:06 +02:00
// ==================================================================
// Print SQL/DB error.
2003-05-28 10:41:04 +02:00
2004-04-26 04:28:06 +02:00
function print_error ( $str = '' ) {
global $EZSQL_ERROR ;
2004-04-26 04:54:06 +02:00
if ( ! $str ) $str = mysql_error ();
$EZSQL_ERROR [] =
array ( 'query' => $this -> last_query , 'error_str' => $str );
2004-04-26 04:28:06 +02:00
2006-07-29 03:44:58 +02:00
$str = htmlspecialchars ( $str , ENT_QUOTES );
$query = htmlspecialchars ( $this -> last_query , ENT_QUOTES );
2004-04-26 04:28:06 +02:00
// Is error output turned on or not..
if ( $this -> show_errors ) {
// If there is an error then take note of it
print " <div id='error'>
2004-11-19 03:18:23 +01:00
< p class = 'wpdberror' >< strong > WordPress database error :</ strong > [ $str ] < br />
2006-07-29 00:57:58 +02:00
< code > $query </ code ></ p >
2004-04-26 04:28:06 +02:00
</ div > " ;
} else {
return false ;
2003-05-28 10:41:04 +02:00
}
2004-04-26 04:28:06 +02:00
}
2003-05-28 10:41:04 +02:00
2004-04-26 04:28:06 +02:00
// ==================================================================
// Turn error handling on or off..
2003-05-28 10:41:04 +02:00
2004-04-26 04:28:06 +02:00
function show_errors () {
$this -> show_errors = true ;
}
function hide_errors () {
$this -> show_errors = false ;
}
2003-05-28 10:41:04 +02:00
2004-04-26 04:28:06 +02:00
// ==================================================================
// Kill cached query results
2003-05-28 10:41:04 +02:00
2004-04-26 04:28:06 +02:00
function flush () {
2006-09-25 03:46:22 +02:00
$this -> last_result = array ();
2004-04-26 04:28:06 +02:00
$this -> col_info = null ;
$this -> last_query = null ;
}
2003-05-28 10:41:04 +02:00
2004-04-26 04:28:06 +02:00
// ==================================================================
// Basic Query - see docs for more detail
2003-05-28 10:41:04 +02:00
2004-04-26 04:28:06 +02:00
function query ( $query ) {
2006-12-07 01:02:24 +01:00
// filter the query, if filters are available
// NOTE: some queries are made before the plugins have been loaded, and thus cannot be filtered with this method
if ( function_exists ( 'apply_filters' ) )
$query = apply_filters ( 'query' , $query );
2004-04-26 04:54:06 +02:00
// initialise return
$return_val = 0 ;
2004-04-26 04:28:06 +02:00
$this -> flush ();
2003-05-28 10:41:04 +02:00
2004-04-26 04:28:06 +02:00
// Log how the function was called
$this -> func_call = " \$ db->query( \" $query\ " ) " ;
// Keep track of the last query for debug..
$this -> last_query = $query ;
// Perform the query via std mysql_query function..
2004-08-20 19:52:49 +02:00
if ( SAVEQUERIES )
$this -> timer_start ();
$this -> result = @ mysql_query ( $query , $this -> dbh );
2004-04-26 04:54:06 +02:00
++ $this -> num_queries ;
2004-08-20 19:52:49 +02:00
if ( SAVEQUERIES )
$this -> queries [] = array ( $query , $this -> timer_stop () );
2004-04-26 04:28:06 +02:00
2004-04-26 04:54:06 +02:00
// If there is an error then take note of it..
if ( mysql_error () ) {
$this -> print_error ();
return false ;
2004-04-26 04:28:06 +02:00
}
2003-05-28 10:41:04 +02:00
2004-04-26 04:54:06 +02:00
if ( preg_match ( " /^ \\ s*(insert|delete|update|replace) /i " , $query ) ) {
$this -> rows_affected = mysql_affected_rows ();
// Take note of the insert_id
if ( preg_match ( " /^ \\ s*(insert|replace) /i " , $query ) ) {
$this -> insert_id = mysql_insert_id ( $this -> dbh );
}
// Return number of rows affected
$return_val = $this -> rows_affected ;
2004-04-26 04:28:06 +02:00
} else {
2004-04-26 04:54:06 +02:00
$i = 0 ;
while ( $i < @ mysql_num_fields ( $this -> result )) {
$this -> col_info [ $i ] = @ mysql_fetch_field ( $this -> result );
$i ++ ;
}
$num_rows = 0 ;
while ( $row = @ mysql_fetch_object ( $this -> result ) ) {
$this -> last_result [ $num_rows ] = $row ;
$num_rows ++ ;
}
2003-05-28 10:41:04 +02:00
2004-04-26 04:54:06 +02:00
@ mysql_free_result ( $this -> result );
2003-05-28 10:41:04 +02:00
2004-04-26 04:54:06 +02:00
// Log number of rows the query returned
$this -> num_rows = $num_rows ;
// Return number of rows selected
$return_val = $this -> num_rows ;
}
2003-05-28 10:41:04 +02:00
2004-04-26 04:54:06 +02:00
return $return_val ;
2004-04-26 04:28:06 +02:00
}
2003-05-28 10:41:04 +02:00
2004-04-26 04:28:06 +02:00
// ==================================================================
// Get one variable from the DB - see docs for more detail
2003-05-28 10:41:04 +02:00
2004-04-26 04:54:06 +02:00
function get_var ( $query = null , $x = 0 , $y = 0 ) {
2004-04-26 04:28:06 +02:00
$this -> func_call = " \$ db->get_var( \" $query\ " , $x , $y ) " ;
2004-04-26 04:54:06 +02:00
if ( $query )
2004-04-26 04:28:06 +02:00
$this -> query ( $query );
2003-05-28 10:41:04 +02:00
2004-04-26 04:28:06 +02:00
// Extract var out of cached results based x,y vals
if ( $this -> last_result [ $y ] ) {
$values = array_values ( get_object_vars ( $this -> last_result [ $y ]));
2003-05-28 10:41:04 +02:00
}
2004-04-26 04:28:06 +02:00
// If there is a value return it else return null
return ( isset ( $values [ $x ]) && $values [ $x ] !== '' ) ? $values [ $x ] : null ;
}
2003-05-28 10:41:04 +02:00
2004-04-26 04:28:06 +02:00
// ==================================================================
// Get one row from the DB - see docs for more detail
2003-05-28 10:41:04 +02:00
2004-04-26 04:54:06 +02:00
function get_row ( $query = null , $output = OBJECT , $y = 0 ) {
2004-04-26 04:28:06 +02:00
$this -> func_call = " \$ db->get_row( \" $query\ " , $output , $y ) " ;
2004-04-26 04:54:06 +02:00
if ( $query )
2004-04-26 04:28:06 +02:00
$this -> query ( $query );
2003-05-28 10:41:04 +02:00
2004-04-26 04:28:06 +02:00
if ( $output == OBJECT ) {
2004-04-26 04:54:06 +02:00
return $this -> last_result [ $y ] ? $this -> last_result [ $y ] : null ;
} elseif ( $output == ARRAY_A ) {
return $this -> last_result [ $y ] ? get_object_vars ( $this -> last_result [ $y ]) : null ;
} elseif ( $output == ARRAY_N ) {
return $this -> last_result [ $y ] ? array_values ( get_object_vars ( $this -> last_result [ $y ])) : null ;
} else {
2004-04-26 04:28:06 +02:00
$this -> print_error ( " \$ db->get_row(string query, output type, int offset) -- Output type must be one of: OBJECT, ARRAY_A, ARRAY_N " );
2003-05-28 10:41:04 +02:00
}
2004-04-26 04:28:06 +02:00
}
2003-05-28 10:41:04 +02:00
2004-04-26 04:28:06 +02:00
// ==================================================================
// Function to get 1 column from the cached result set based in X index
// se docs for usage and info
2004-04-26 04:54:06 +02:00
function get_col ( $query = null , $x = 0 ) {
if ( $query )
2004-04-26 04:28:06 +02:00
$this -> query ( $query );
2004-04-26 04:54:06 +02:00
2004-04-26 04:28:06 +02:00
// Extract the column values
for ( $i = 0 ; $i < count ( $this -> last_result ); $i ++ ) {
2004-04-26 04:54:06 +02:00
$new_array [ $i ] = $this -> get_var ( null , $x , $i );
2004-04-26 04:28:06 +02:00
}
return $new_array ;
}
2003-05-28 10:41:04 +02:00
2004-04-26 04:28:06 +02:00
// ==================================================================
// Return the the query as a result set - see docs for more details
2003-05-28 10:41:04 +02:00
2004-04-26 04:54:06 +02:00
function get_results ( $query = null , $output = OBJECT ) {
2004-04-26 04:28:06 +02:00
$this -> func_call = " \$ db->get_results( \" $query\ " , $output ) " ;
2003-05-28 10:41:04 +02:00
2004-04-26 04:54:06 +02:00
if ( $query )
2004-04-26 04:28:06 +02:00
$this -> query ( $query );
2003-05-28 10:41:04 +02:00
2004-04-26 04:28:06 +02:00
// Send back array of objects. Each row is an object
if ( $output == OBJECT ) {
return $this -> last_result ;
} elseif ( $output == ARRAY_A || $output == ARRAY_N ) {
if ( $this -> last_result ) {
2004-04-26 04:54:06 +02:00
$i = 0 ;
2004-04-26 04:28:06 +02:00
foreach ( $this -> last_result as $row ) {
$new_array [ $i ] = ( array ) $row ;
if ( $output == ARRAY_N ) {
$new_array [ $i ] = array_values ( $new_array [ $i ]);
2003-05-28 10:41:04 +02:00
}
2004-04-26 04:28:06 +02:00
$i ++ ;
2003-05-28 10:41:04 +02:00
}
2004-04-26 04:28:06 +02:00
return $new_array ;
} else {
return null ;
2003-05-28 10:41:04 +02:00
}
}
2004-04-26 04:28:06 +02:00
}
2003-05-28 10:41:04 +02:00
2004-04-26 04:28:06 +02:00
// ==================================================================
// Function to get column meta data info pertaining to the last query
// see docs for more info and usage
2003-05-28 10:41:04 +02:00
2004-04-26 04:54:06 +02:00
function get_col_info ( $info_type = 'name' , $col_offset = - 1 ) {
2004-04-26 04:28:06 +02:00
if ( $this -> col_info ) {
if ( $col_offset == - 1 ) {
2004-04-26 04:54:06 +02:00
$i = 0 ;
2004-04-26 04:28:06 +02:00
foreach ( $this -> col_info as $col ) {
$new_array [ $i ] = $col -> { $info_type };
$i ++ ;
2003-05-28 10:41:04 +02:00
}
2004-04-26 04:28:06 +02:00
return $new_array ;
} else {
return $this -> col_info [ $col_offset ] -> { $info_type };
2003-05-28 10:41:04 +02:00
}
}
}
2004-07-23 03:35:56 +02:00
2004-08-20 19:52:49 +02:00
function timer_start () {
$mtime = microtime ();
$mtime = explode ( ' ' , $mtime );
$this -> time_start = $mtime [ 1 ] + $mtime [ 0 ];
return true ;
2004-07-23 03:35:56 +02:00
}
2004-08-20 19:52:49 +02:00
function timer_stop ( $precision = 3 ) {
$mtime = microtime ();
$mtime = explode ( ' ' , $mtime );
$time_end = $mtime [ 1 ] + $mtime [ 0 ];
$time_total = $time_end - $this -> time_start ;
2004-08-20 19:56:51 +02:00
return $time_total ;
2004-07-23 03:35:56 +02:00
}
2004-08-20 19:52:49 +02:00
function bail ( $message ) { // Just wraps errors in a nice header and footer
if ( ! $this -> show_errors )
return false ;
2005-05-13 22:31:59 +02:00
header ( 'Content-Type: text/html; charset=utf-8' );
2004-08-20 19:52:49 +02:00
echo <<< HEAD
<! DOCTYPE html PUBLIC " -//W3C//DTD XHTML 1.0 Transitional//EN " " http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd " >
< html xmlns = " http://www.w3.org/1999/xhtml " >
< head >
< title > WordPress & rsaquo ; Error </ title >
< meta http - equiv = " Content-Type " content = " text/html; charset=utf-8 " />
< style media = " screen " type = " text/css " >
<!--
html {
background : #eee;
}
body {
background : #fff;
color : #000;
font - family : Georgia , " Times New Roman " , Times , serif ;
margin - left : 25 % ;
margin - right : 25 % ;
padding : . 2 em 2 em ;
}
h1 {
color : #006;
font - size : 18 px ;
font - weight : lighter ;
}
h2 {
font - size : 16 px ;
}
p , li , dt {
line - height : 140 % ;
padding - bottom : 2 px ;
}
ul , ol {
padding : 5 px 5 px 5 px 20 px ;
}
#logo {
margin - bottom : 2 em ;
}
-->
</ style >
</ head >
< body >
< h1 id = " logo " >< img alt = " WordPress " src = " http://static.wordpress.org/logo.png " /></ h1 >
2004-07-23 03:35:56 +02:00
HEAD ;
2004-08-20 19:52:49 +02:00
echo $message ;
echo " </body></html> " ;
die ();
2004-07-23 03:35:56 +02:00
}
2004-04-26 04:28:06 +02:00
}
2003-05-29 16:04:30 +02:00
$wpdb = new wpdb ( DB_USER , DB_PASSWORD , DB_NAME , DB_HOST );
2003-05-28 10:41:04 +02:00
?>