| 1 |
<?php |
|---|
| 2 |
|
|---|
| 3 |
|
|---|
| 4 |
|
|---|
| 5 |
|
|---|
| 6 |
|
|---|
| 7 |
|
|---|
| 8 |
|
|---|
| 9 |
|
|---|
| 10 |
|
|---|
| 11 |
|
|---|
| 12 |
|
|---|
| 13 |
|
|---|
| 14 |
|
|---|
| 15 |
|
|---|
| 16 |
|
|---|
| 17 |
|
|---|
| 18 |
|
|---|
| 19 |
|
|---|
| 20 |
|
|---|
| 21 |
require_once(INCLUDEPATH . '/class.database.php'); |
|---|
| 22 |
|
|---|
| 23 |
Config::set('DB_TYPE', Config::get('DATABASE_TYPE')); |
|---|
| 24 |
Config::set('DB_HOST', Config::get('DATABASE_HOST')); |
|---|
| 25 |
Config::set('DB_USER', Config::get('DATABASE_USER')); |
|---|
| 26 |
Config::set('DB_PASS', decrypt_db_password(Config::get('DATABASE_PASSWORD'))); |
|---|
| 27 |
Config::set('DB_NAME', Config::get('DATABASE_NAME')); |
|---|
| 28 |
|
|---|
| 29 |
|
|---|
| 30 |
@$sql = Database::connect(Config::get('DB_USER'), Config::get('DB_PASS'), Config::get('DB_TYPE'), Config::get('DB_HOST'), Config::get('DB_NAME')) |
|---|
| 31 |
or system_message('ERROR: Unable to connect to SQL server !<br>SQL returned: ' . $sql->ErrorMsg()); |
|---|
| 32 |
|
|---|
| 33 |
|
|---|
| 34 |
if (Config::exists('DATABASE_UTF8') && Config::get('DATABASE_UTF8') == 'yes') { |
|---|
| 35 |
@$sql->Execute("SET NAMES 'utf8'"); |
|---|
| 36 |
} |
|---|
| 37 |
|
|---|
| 38 |
|
|---|
| 39 |
Config::set('DB_USER', null); |
|---|
| 40 |
Config::set('DB_PASS', null); |
|---|
| 41 |
|
|---|
| 42 |
function execute_query (&$sql, $query) { |
|---|
| 43 |
$rs = $sql->Execute($query); |
|---|
| 44 |
if (!$rs) system_message($sql->ErrorMsg()); |
|---|
| 45 |
return $rs; |
|---|
| 46 |
} |
|---|
| 47 |
|
|---|
| 48 |
function exec_query(&$sql, $query, $data = array(), $failDie = true) { |
|---|
| 49 |
$query = $sql->Prepare($query); |
|---|
| 50 |
$rs = $sql->Execute($query, $data); |
|---|
| 51 |
|
|---|
| 52 |
if (!$rs && $failDie) { |
|---|
| 53 |
|
|---|
| 54 |
|
|---|
| 55 |
if($query instanceof PDOStatement) |
|---|
| 56 |
$msg = $query->errorInfo(); |
|---|
| 57 |
|
|---|
| 58 |
$msg = $sql->errorInfo(); |
|---|
| 59 |
system_message(isset($msg[2]) ? $msg[2] : $msg); |
|---|
| 60 |
|
|---|
| 61 |
|
|---|
| 62 |
$rs; |
|---|
| 63 |
|
|---|
| 64 |
|
|---|
| 65 |
quoteIdentifier($identifier) { |
|---|
| 66 |
$sql = Database::getInstance(); |
|---|
| 67 |
|
|---|
| 68 |
$identifier = str_replace($sql->nameQuote, '\\' . $sql->nameQuote, $identifier); |
|---|
| 69 |
|
|---|
| 70 |
$sql->nameQuote . $identifier . $sql->nameQuote; |
|---|
| 71 |
|
|---|
| 72 |
|
|---|
| 73 |
match_sqlinjection($value, &$matches) { |
|---|
| 74 |
$matches = array(); |
|---|
| 75 |
preg_match("/((DELETE)|(INSERT)|(UPDATE)|(ALTER)|(CREATE)|( TABLE)|(DROP))\s[A-Za-z0-9 ]{0,200}(\s(FROM)|(INTO)|(TABLE)\s)/i", $value, $matches) > 0); |
|---|
| 76 |
|
|---|
| 77 |
|
|---|
| 78 |
check_query($exclude = array()) { |
|---|
| 79 |
$matches = null; |
|---|
| 80 |
|
|---|
| 81 |
phpversion() <= '4.2.2') { |
|---|
| 82 |
$message = "Your PHP version is older than 4.2.2!"; |
|---|
| 83 |
write_log($message); |
|---|
| 84 |
system_message($message); |
|---|
| 85 |
'ERROR: Your PHP version is older than 4.2.2!'); |
|---|
| 86 |
|
|---|
| 87 |
|
|---|
| 88 |
is_array($exclude)) { |
|---|
| 89 |
$exclude = array($exclude); |
|---|
| 90 |
|
|---|
| 91 |
|
|---|
| 92 |
$_REQUEST as $key => $value) { |
|---|
| 93 |
in_array($key, $exclude)) { |
|---|
| 94 |
|
|---|
| 95 |
|
|---|
| 96 |
|
|---|
| 97 |
is_array($value)) { |
|---|
| 98 |
match_sqlinjection($value, $matches)) { |
|---|
| 99 |
$message = "Possible SQL injection detected: $key=>$value. <b>${matches[0]}</b>. Script terminated."; |
|---|
| 100 |
write_log($message); |
|---|
| 101 |
system_message($message); |
|---|
| 102 |
'<b>WARNING</b>: Possible SQL injection detected. Script terminated.'); |
|---|
| 103 |
|
|---|
| 104 |
|
|---|
| 105 |
$value as $skey => $svalue) { |
|---|
| 106 |
is_array($svalue)) { |
|---|
| 107 |
match_sqlinjection($svalue, $matches)) { |
|---|
| 108 |
$message = "Possible SQL injection detected: $skey=>$svalue <b>${matches[0]}</b>. Script terminated."; |
|---|
| 109 |
write_log($message); |
|---|
| 110 |
system_message($message); |
|---|
| 111 |
'<b>WARNING</b>: Possible SQL injection detected. Script terminated.'); |
|---|
| 112 |
|
|---|
| 113 |
|
|---|
| 114 |
|
|---|
| 115 |
|
|---|
| 116 |
|
|---|
| 117 |
|
|---|
| 118 |
|
|---|
| 119 |
?> |
|---|