<?php # sql functions, currently only set up to work with MySql # replace functions in this file to make it work with other Databases if (!function_exists("mysqli_init")) { header('HTTP/1.0 500 Mysqli functionality missing'); print "Fatal Error: Mysql is not supported in your PHP, recompile and try again."; exit; } function Sql_Connect($host, $user, $password, $database) { global $database_port, $database_socket, $database_connection_compression, $database_connection_ssl; if (!$host || !$user) { header('HTTP/1.0 500 Cannot connect to database'); print "Cannot connect to Database, host and user are required. Please check your configuration"; exit; } $db = mysqli_init(); $compress = empty($database_connection_compression) ? 0 : MYSQLI_CLIENT_COMPRESS; $secure = empty($database_connection_ssl) ? 0 : MYSQLI_CLIENT_SSL_DONT_VERIFY_SERVER_CERT; mysqli_report(MYSQLI_REPORT_OFF); if (!mysqli_real_connect($db, $host, $user, $password, $database, $database_port, $database_socket, $compress | $secure)) { $errno = mysqli_connect_errno(); if (isset($GLOBALS['plugins']) && is_array($GLOBALS['plugins'])) { foreach ($GLOBALS['plugins'] as $pluginname => $plugin) { $plugin->processDBerror($errno); } } switch ($errno) { case 1049: # unknown database header('HTTP/1.0 500 Unknown database'); print "Unknown database, cannot continue"; exit; case 1045: # access denied header('HTTP/1.0 500 Cannot connect to database, access denied'); print "Cannot connect to database, access denied. Please check your configuration or contact the administrator."; exit; case 2002: header('HTTP/1.0 500 Cannot connect to database, server not running'); print "Cannot connect to database, Sql server is not running. Please check your configuration or contact the administrator."; exit; case 1040: # too many connections header('HTTP/1.0 500 Cannot connect to database, server too busy'); print "Sorry, the server is currently too busy, please try again later."; exit; case 2005: # "unknown host" header('HTTP/1.0 500 Cannot connect to database, unknown host'); print "Unknown database host to connected to, please check your configuration"; exit; case 2006: # "gone away" header('HTTP/1.0 500 Cannot connect to database, server gone away'); if ($compress || $secure) { print "Verify that your 'compress' or 'secure' setting for DB connections are supported by your database server.<br/>"; } print "Sorry, the server is currently too busy, please try again later."; exit; case 0: break; default: if (isset($GLOBALS['database_connection'])) { print SQL_Error($GLOBALS['database_connection'], $errno); } else { header('HTTP/1.0 500 Cannot connect to database'); print "Cannot connect to Database, please check your configuration"; } } exit; } if (!$db) { header('HTTP/1.0 500 Cannot connect to database'); print "Cannot connect to Database, please check your configuration"; exit; } mysqli_query($db, "SET NAMES 'utf8'"); unset($GLOBALS['lastquery']); return $db; } function Sql_has_error($dbconnection) { return mysqli_errno($dbconnection); } function Sql_Error($dbconnection, $errno = 0) { $msg = mysqli_error($dbconnection); if (!isset($GLOBALS['lastquery'])) { $GLOBALS['lastquery'] = ""; } if (empty($GLOBALS['commandline'])) { /* output('DB error'.$errno); print debug_print_backtrace(); */ return '<div id="dberror">Database error ' . $errno . ' while doing query ' . $GLOBALS['lastquery'] . ' ' . $msg . '</div>'; } else { cl_output('Database error ' . $errno . ' while doing query ' . $GLOBALS['lastquery'] . ' ' . $msg); } if (function_exists("logevent")) { logevent("Database error: $msg"); } # return "<table class="x" border=1><tr><td class=\"error\">Database Error</td></tr><tr><td><!--$errno: -->$msg</td></tr></table>"; } function Sql_Check_error($dbconnection, $errno = 0) { if (!$errno) { $errno = Sql_has_error($dbconnection); } if ($errno) { switch ($errno) { case 1049: # unknown database Fatal_Error("unknown database, cannot continue"); exit; case 1045: # access denied Fatal_Error("Cannot connect to database, access denied. Please contact the administrator"); exit; case 2002: Fatal_Error("Cannot connect to database, Sql server is not running. Please contact the administrator"); exit; case 1040: # too many connections Fatal_Error("Sorry, the server is currently too busy, please try again later."); exit; case 0: break; default: print Sql_error($dbconnection, $errno); } return 1; } } function Sql_Query($query, $ignore = 0) { if (empty($GLOBALS['database_connection'])) { $GLOBALS['database_connection'] = Sql_Connect( $GLOBALS['database_host'], $GLOBALS['database_user'], $GLOBALS['database_password'], $GLOBALS['database_name']); } if (isset($GLOBALS['lastquery'])) { unset($GLOBALS['lastquery']); } if (isset($GLOBALS["developer_email"]) && !empty($GLOBALS["developer_logqueries"])) { sqllog($query, '/tmp/queries.log'); # time queries to see how slow they are, so they can # be optimized $now = gettimeofday(); $start = $now["sec"] * 1000000 + $now["usec"]; $GLOBALS['lastquery'] = $query; # keep track of queries to see which ones to optimize if (function_exists('stripos')) { if (!stripos($query, 'WebblerSessions') && !stripos($query, 'cache')) { $store = $query; $store = preg_replace('/\d+/', 'X', $store); $store = trim($store); @mysqli_query($GLOBALS['database_connection'], sprintf('update querycount set count = count + 1 where query = "%s" and frontend = %d', $store, $frontend)); if (mysqli_affected_rows($GLOBALS['database_connection']) != 2) { @mysqli_query($GLOBALS['database_connection'], sprintf('insert into querycount set count = count + 1 , query = "%s",phplist = 1', $store)); } } } } $GLOBALS["pagestats"]["number_of_queries"]++; $result = mysqli_query($GLOBALS['database_connection'], $query); if (!$ignore) { if (Sql_Check_Error($GLOBALS["database_connection"])) { # dbg("Sql error in $query"); cl_output('Sql error ' . $query); } } if (isset($GLOBALS["developer_email"]) && !empty($GLOBALS["developer_logqueries"])) { # log time queries take $now = gettimeofday(); $end = $now["sec"] * 1000000 + $now["usec"]; $elapsed = $end - $start; if ($elapsed > 300000) { $query = substr($query, 0, 2000); sqllog(' [' . secs2time($elapsed) . '] ' . $query, "/tmp/phplist-sqltimer.log"); } else { # sqllog(' ['.$elapsed.'] '.$query,"/tmp/phplist-sqltimer.log"); } } return $result; } function Sql_Close() { mysqli_close($GLOBALS["database_connection"]); unset($GLOBALS["database_connection"]); } function Sql_Query_Params($query, $params, $ignore = 0) { if (empty($GLOBALS['database_connection'])) { $GLOBALS['database_connection'] = Sql_Connect( $GLOBALS['database_host'], $GLOBALS['database_user'], $GLOBALS['database_password'], $GLOBALS['database_name']); } if (!is_array($params)) { $params = Array($params); } foreach ($params as $index => $par) { $qmark = strpos($query, '?'); if ($qmark === false) { # dbg("Error, more parameters than placeholders"); } else { ## first replace the ? with some other placeholder, in case the parameters contain ? themselves $query = substr($query, 0, $qmark) . '"PARAM' . $index . 'MARAP"' . substr($query, $qmark + 1); } } foreach ($params as $index => $par) { if (is_numeric($par)) { $query = str_replace('"PARAM' . $index . 'MARAP"', sql_escape($par), $query); } else { $query = str_replace('PARAM' . $index . 'MARAP', sql_escape($par), $query); } } return Sql_Query($query, $ignore); } function sqllog($msg, $logfile = "") { if (!$logfile) { return; } $fp = @fopen($logfile, "a"); $line = "[" . date("d M Y, H:i:s") . "] " . getenv("REQUEST_URI") . '(' . $GLOBALS["pagestats"]["number_of_queries"] . ") $msg \n"; @fwrite($fp, $line); @fclose($fp); } function Sql_Verbose_Query($query, $ignore = 0) { if (isset($GLOBALS['developer_email'])) { print "<b>$query</b><br>\n"; } flush(); if (!empty($GLOBALS["commandline"])) { ob_end_clean(); print "Sql: $query\n"; ob_start(); } return Sql_Query($query, $ignore); } function Sql_Fetch_Array($dbresult) { return mysqli_fetch_array($dbresult); } function Sql_Fetch_Assoc($dbresult) { return mysqli_fetch_assoc($dbresult); } function Sql_Fetch_Row($dbresult) { if ($dbresult) { return mysqli_fetch_row($dbresult); } return false; } function Sql_Fetch_Row_Query($query, $ignore = 0) { $req = Sql_Query($query, $ignore); return Sql_Fetch_Row($req); } function Sql_Fetch_Array_Query($query, $ignore = 0) { $req = Sql_Query($query, $ignore); return Sql_Fetch_Array($req); } function Sql_Fetch_Assoc_Query($query, $ignore = 0) { $req = Sql_Query($query, $ignore); return Sql_Fetch_Assoc($req); } function Sql_Affected_Rows() { return mysqli_affected_rows($GLOBALS["database_connection"]); } function Sql_Num_Rows($result = "") { return mysqli_num_rows($result); } function Sql_Insert_Id() { return mysqli_insert_id($GLOBALS["database_connection"]); } function Sql_Free_Result($dbresult) { mysqli_free_result($dbresult); } ; function Sql_Table_exists($table, $refresh = 0) { ## table is the full table name including the prefix if (!empty($_GET['pi']) || $refresh || !isset($_SESSION) || !isset($_SESSION["dbtables"]) || !is_array($_SESSION["dbtables"])) { $_SESSION["dbtables"] = array(); # need to improve this. http://bugs.mysql.com/bug.php?id=19588 $req = Sql_Query('select table_name from information_schema.tables where table_schema = "' . $GLOBALS['database_name'] . '"'); while ($row = Sql_Fetch_Row($req)) { array_push($_SESSION["dbtables"], $row[0]); } } return in_array($table, $_SESSION["dbtables"]); } function Sql_Table_Column_Exists($table, $column) { ## table is the full table name including the prefix if (Sql_Table_exists($table)) { # need to improve this. http://bugs.mysql.com/bug.php?id=19588 $req = Sql_Query("show columns from $table"); while ($row = Sql_Fetch_Row($req)) { if ($row[0] == $column) { return 1; } } } } /** * Check if a specific INDEX exists in a specific table * @param string $table The table name * @param string $index The key name * @return bool */ function table_index_exists($table, $index) { $e = false; if ($result = Sql_Query("SHOW INDEX FROM $table WHERE Key_name = '$index'")) { if($result->num_rows >= 1) { $e = true; } } mysqli_free_result($result); return $e; } function Sql_Check_For_Table($table) { ## table is the full table name including the prefix, or the abbreviated one without prefix return Sql_Table_exists($table) || (isset($GLOBALS['tables'][$table]) && Sql_Table_exists($GLOBALS['tables'][$table])); } function createTable($table) { ## table is the abbreviated table name one without prefix if (!isset($GLOBALS['tables'][$table])) { return false; } include dirname(__FILE__) . '/structure.php'; if (!empty($DBstruct[$table]) && is_array($DBstruct[$table])) { Sql_Create_table($GLOBALS['tables'][$table], $DBstruct[$table]); return true; } return false; } function Sql_create_Table($table, $structure) { $query = "CREATE TABLE $table (\n"; foreach ($structure as $column => $val) { if (preg_match('/index_\d+/', $column)) { $query .= "index " . $structure[$column][0] . ","; } elseif (preg_match('/unique_\d+/', $column)) { $query .= "unique " . $structure[$column][0] . ","; } else { $query .= "$column " . $structure[$column][0] . ","; } } # get rid of the last , $query = substr($query, 0, -1); $query .= "\n) default character set utf8"; # submit it to the database $res = Sql_Query($query, 1); unset($_SESSION["dbtables"]); } function sql_escape($text) { if (empty($GLOBALS['database_connection'])) { $GLOBALS['database_connection'] = Sql_Connect( $GLOBALS['database_host'], $GLOBALS['database_user'], $GLOBALS['database_password'], $GLOBALS['database_name']); } if (!empty($GLOBALS['database_connection'])) { return mysqli_real_escape_string($GLOBALS['database_connection'], $text); } else { ## better than returning $text. This is very much in the beginning when the DB connection hasn't been created yet. return ''; } }
Name | Type | Size | Permission | Actions |
---|---|---|---|---|
PEAR | Folder | 0755 |
|
|
PHPMailer | Folder | 0755 |
|
|
PHPMailer6 | Folder | 0755 |
|
|
actions | Folder | 0755 |
|
|
css | Folder | 0755 |
|
|
data | Folder | 0755 |
|
|
help | Folder | 0755 |
|
|
images | Folder | 0755 |
|
|
inc | Folder | 0755 |
|
|
info | Folder | 0755 |
|
|
js | Folder | 0755 |
|
|
locale | Folder | 0755 |
|
|
onyxrss | Folder | 0755 |
|
|
plugins | Folder | 0755 |
|
|
tests | Folder | 0755 |
|
|
ui | Folder | 0755 |
|
|
.gitignore | File | 20 B | 0644 |
|
.htaccess | File | 489 B | 0644 |
|
.minceconf | File | 994 B | 0644 |
|
AnalyticsQuery.php | File | 985 B | 0644 |
|
CsvReader.php | File | 1.27 KB | 0644 |
|
EmailSender.php | File | 477 B | 0644 |
|
Updater.php | File | 193 B | 0644 |
|
about.php | File | 7.4 KB | 0644 |
|
accesscheck.php | File | 715 B | 0644 |
|
addprefix.php | File | 1.01 KB | 0644 |
|
adduser.php | File | 46 B | 0644 |
|
admin.php | File | 12.77 KB | 0644 |
|
adminattributes.php | File | 7.46 KB | 0644 |
|
admins.php | File | 5.16 KB | 0644 |
|
analytics.php | File | 2.84 KB | 0644 |
|
attributes.php | File | 26.2 KB | 0644 |
|
blacklistemail.php | File | 1.22 KB | 0644 |
|
bounce.php | File | 11.14 KB | 0644 |
|
bouncemgt.php | File | 1.44 KB | 0644 |
|
bouncerule.php | File | 4.27 KB | 0644 |
|
bouncerules.php | File | 6.33 KB | 0644 |
|
bounces.php | File | 7.57 KB | 0644 |
|
catlists.php | File | 3.34 KB | 0644 |
|
checkbouncerules.php | File | 1.43 KB | 0644 |
|
checki18n.php | File | 3.13 KB | 0644 |
|
checkprerequisites.php | File | 1.62 KB | 0644 |
|
class.image.inc | File | 3.9 KB | 0644 |
|
class.phplistmailer.php | File | 30.73 KB | 0644 |
|
class.phplistmailerbase.php | File | 1.67 KB | 0644 |
|
community.php | File | 3.5 KB | 0644 |
|
communityfeed.php | File | 2.36 KB | 0644 |
|
configure.php | File | 7.85 KB | 0644 |
|
connect.php | File | 89.86 KB | 0644 |
|
convertstats.php | File | 5.83 KB | 0644 |
|
converttoutf8.php | File | 3.78 KB | 0644 |
|
cron.php | File | 3.34 KB | 0644 |
|
date.php | File | 7.65 KB | 0644 |
|
dbcheck.php | File | 3.7 KB | 0644 |
|
defaultFrontendTexts.php | File | 9.79 KB | 0644 |
|
defaultconfig.php | File | 30.66 KB | 0644 |
|
defaultplugin.php | File | 31.59 KB | 0644 |
|
defaults.php | File | 3.64 KB | 0644 |
|
defaultsystemtemplate.php | File | 15.29 KB | 0644 |
|
defaulttest.php | File | 1.23 KB | 0644 |
|
dlusers.php | File | 235 B | 0644 |
|
domainbounces.php | File | 507 B | 0644 |
|
domainstats.php | File | 371 B | 0644 |
|
editattributes.php | File | 8.78 KB | 0644 |
|
editlist.php | File | 7.4 KB | 0644 |
|
eventlog.php | File | 4.68 KB | 0644 |
|
export.php | File | 6.86 KB | 0644 |
|
exportuserdata.php | File | 8.26 KB | 0644 |
|
fckphplist.php | File | 49.84 KB | 0644 |
|
gchart.php | File | 903 B | 0644 |
|
generatebouncerules.php | File | 5.51 KB | 0644 |
|
home.php | File | 6.56 KB | 0644 |
|
hostedprocessqueuesetup.php | File | 3.09 KB | 0644 |
|
htaccess | File | 311 B | 0644 |
|
image.php | File | 2.01 KB | 0644 |
|
import.php | File | 2.75 KB | 0644 |
|
import1.php | File | 11.09 KB | 0644 |
|
import2.php | File | 34.16 KB | 0644 |
|
import3.php | File | 22.72 KB | 0644 |
|
import4.php | File | 16.86 KB | 0644 |
|
importadmin.php | File | 17.08 KB | 0644 |
|
importsimple.php | File | 7.32 KB | 0644 |
|
index.php | File | 32.82 KB | 0644 |
|
info.php | File | 1.07 KB | 0644 |
|
init.php | File | 27.36 KB | 0644 |
|
initialise.php | File | 12.05 KB | 0644 |
|
initlanguages.php | File | 867 B | 0644 |
|
languages.php | File | 21.37 KB | 0644 |
|
lib.php | File | 86.79 KB | 0644 |
|
list.php | File | 11.32 KB | 0644 |
|
listbounces.php | File | 4.13 KB | 0644 |
|
login.php | File | 6.39 KB | 0644 |
|
logout.php | File | 865 B | 0644 |
|
massremove.php | File | 2.55 KB | 0644 |
|
mclicks.php | File | 7.28 KB | 0644 |
|
members.php | File | 19.99 KB | 0644 |
|
mergeduplicates.php | File | 4.48 KB | 0644 |
|
message.php | File | 9.08 KB | 0644 |
|
messages.php | File | 26.27 KB | 0644 |
|
minify.txt | File | 201 B | 0644 |
|
msgbounces.php | File | 3.4 KB | 0644 |
|
msgstatus.php | File | 1.27 KB | 0644 |
|
mviews.php | File | 6.27 KB | 0644 |
|
mysql.inc | File | 40 B | 0644 |
|
mysqli.inc | File | 14.02 KB | 0644 |
|
pageaction.php | File | 1.11 KB | 0644 |
|
phpListAdminAuthentication.php | File | 6.82 KB | 0644 |
|
pluginlib.php | File | 9.43 KB | 0644 |
|
plugins.php | File | 17.78 KB | 0644 |
|
preparesend.php | File | 669 B | 0644 |
|
processbounces.php | File | 35.36 KB | 0644 |
|
processqueue.php | File | 3.71 KB | 0644 |
|
readtestmail.php | File | 11.59 KB | 0644 |
|
reconcileusers.php | File | 27.71 KB | 0644 |
|
redirecttoupdater.php | File | 187 B | 0644 |
|
reindex.php | File | 1.82 KB | 0644 |
|
rsslib.php | File | 3.17 KB | 0644 |
|
runcommand.php | File | 583 B | 0644 |
|
send.php | File | 6.17 KB | 0644 |
|
send_core.php | File | 63.91 KB | 0644 |
|
sendemaillib.php | File | 69.84 KB | 0644 |
|
sendprepared.php | File | 4.87 KB | 0644 |
|
sessionlib.php | File | 2.7 KB | 0644 |
|
setpermissions.php | File | 2.08 KB | 0644 |
|
setup.php | File | 2.56 KB | 0644 |
|
spage.php | File | 4.35 KB | 0644 |
|
spageedit.php | File | 19.08 KB | 0644 |
|
statsmgt.php | File | 1.23 KB | 0644 |
|
statsoverview.php | File | 6.19 KB | 0644 |
|
stresstest.php | File | 4.82 KB | 0644 |
|
structure.php | File | 29.21 KB | 0644 |
|
subscribelib2.php | File | 70.22 KB | 0644 |
|
subscriberstats.php | File | 617 B | 0644 |
|
suppressionlist.php | File | 1.71 KB | 0644 |
|
system.php | File | 795 B | 0644 |
|
systemstats.php | File | 5.73 KB | 0644 |
|
template.php | File | 16.4 KB | 0644 |
|
templates.php | File | 3.01 KB | 0644 |
|
tests.php | File | 1.67 KB | 0644 |
|
uclicks.php | File | 6.74 KB | 0644 |
|
update.php | File | 187 B | 0644 |
|
updateLib.php | File | 2.2 KB | 0644 |
|
updatetlds.php | File | 358 B | 0644 |
|
updatetranslation.php | File | 2.51 KB | 0644 |
|
upgrade.php | File | 23.82 KB | 0644 |
|
user.php | File | 23.08 KB | 0644 |
|
usercheck.php | File | 2.55 KB | 0644 |
|
userclicks.php | File | 11.57 KB | 0644 |
|
userhistory.php | File | 8.25 KB | 0644 |
|
usermgt.php | File | 1.9 KB | 0644 |
|
users.php | File | 19.3 KB | 0644 |
|
vCard.php | File | 1.9 KB | 0644 |
|
viewmessage.php | File | 635 B | 0644 |
|
viewtemplate.php | File | 1.86 KB | 0644 |
|
vote.php | File | 38 B | 0644 |
|