1
0
mirror of https://github.com/e107inc/e107.git synced 2025-01-17 20:58:30 +01:00

1219 lines
29 KiB
PHP

<?php
/*
* e107 website system
*
* Copyright (C) 2001-2008 e107 Inc (e107.org)
* Released under the terms and conditions of the
* GNU General Public License (http://www.gnu.org/licenses/gpl.txt)
*
* Administration - Database Utilities
*
* $Source: /cvs_backup/e107_0.8/e107_admin/db.php,v $
* $Revision: 1.17 $
* $Date: 2009-08-27 21:01:40 $
* $Author: e107coders $
*
*/
require_once ("../class2.php");
require_once (e_HANDLER."form_handler.php");
$frm = new e_form();
if(!getperms('0'))
{
header('location:'.e_BASE.'index.php');
exit();
}
$e_sub_cat = 'database';
if(isset($_POST['back']))
{
header("location: ".e_SELF);
exit();
}
require_once (e_HANDLER."message_handler.php");
$emessage = &eMessage::getInstance();
/*
* Execute trigger
*/
if(isset($_POST['trigger_db_execute']))
{
if(!varset($_POST['db_execute']))
{
$emessage->add(DBLAN_53, E_MESSAGE_WARNING);
}
else
{
$_POST[$_POST['db_execute']] = true;
}
}
if(isset($_POST['db_update']))
{
header("location: ".e_ADMIN."e107_update.php");
exit();
}
if(isset($_POST['verify_sql']))
{
header("location: ".e_ADMIN."db_verify.php");
exit();
}
if(isset($_POST['exportXmlFile']))
{
exportXmlFile();
exit();
}
require_once ("auth.php");
require_once (e_HANDLER."form_handler.php");
$frm = new e_form();
$emessage = &eMessage::getInstance(); //nothing wrong with doing it twice
if(isset($_POST['importCorePrefsForm']))
{
importCorePrefsForm();
}
if(isset($_POST['exportForm']))
{
exportXmlForm();
exit();
}
if(isset($_POST['delpref']) || (isset($_POST['delpref_checked']) && isset($_POST['delpref2'])))
{
del_pref_val();
}
if(isset($_POST['pref_editor']) || isset($_POST['delpref']) || isset($_POST['delpref_checked']))
{
pref_editor();
require_once ("footer.php");
exit();
}
if(isset($_POST['optimize_sql']))
{
optimizesql($mySQLdefaultdb);
}
if(isset($_POST['sc_override_scan']))
{
scan_override();
}
if(isset($_POST['backup_core']))
{
backup_core();
//message_handler("MESSAGE", DBLAN_1);
$emessage->add(DBLAN_1, E_MESSAGE_SUCCESS);
}
if(isset($_POST['delplug']))
{
delete_plugin_entry();
}
if(isset($_POST['plugin_scan']) || e_QUERY == "plugin" || $_POST['delplug'])
{
plugin_viewscan();
require_once ("footer.php");
exit();
}
if(isset($_POST['verify_sql_record']) || isset($_POST['check_verify_sql_record']) || isset($_POST['delete_verify_sql_record']))
{
verify_sql_record();
require_once ("footer.php");
exit();
}
if(isset($_POST['upload']))
{
importCorePrefs();
}
//XXX - what is this for (backup core)? <input type='hidden' name='sqltext' value='{$sqltext}' />
$text = "
<form method='post' action='".e_SELF."' id='core-db-main-form'>
<fieldset id='core-db-plugin-scan'>
<legend class='e-hideme'>".DBLAN_10."</legend>
<table cellpadding='0' cellspacing='0' class='adminlist'>
<colgroup span='2'>
<col style='width: 60%'></col>
<col style='width: 40%'></col>
</colgroup>
<tbody>
<!-- CHECK FOR UPDATES -->
<tr>
<td>".DBLAN_15."</td>
<td>
".$frm->radio('db_execute', 'db_update').$frm->label(DBLAN_16, 'db_execute', 'db_update')."
</td>
</tr>
<!-- CHECK DATABASE VALIDITY -->
<tr>
<td>".DBLAN_4."</td>
<td>
".$frm->radio('db_execute', 'verify_sql').$frm->label(DBLAN_5, 'db_execute', 'verify_sql')."
</td>
</tr>
<!-- OPTIMIZE SQL DATABASE -->
<tr>
<td>".DBLAN_6."</td>
<td>
".$frm->radio('db_execute', 'optimize_sql').$frm->label(DBLAN_7, 'db_execute', 'optimize_sql')."
</td>
</tr>
<!-- SCAN PLUGIN DIRECTORIES -->
<tr>
<td>".DBLAN_28."</td>
<td>
".$frm->radio('db_execute', 'plugin_scan').$frm->label(DBLAN_29, 'db_execute', 'plugin_scan')."
</td>
</tr>
<!-- PREFERENCE EDITOR -->
<tr>
<td>".DBLAN_19."</td>
<td>
".$frm->radio('db_execute', 'pref_editor').$frm->label(DBLAN_20, 'db_execute', 'pref_editor')."
</td>
</tr>";
// TODO - do we still really need Backup-Core, when we have an XML export?
$text .= "
<!-- BACKUP CORE -->
<tr>
<td>".DBLAN_8."</td>
<td>
".$frm->radio('db_execute', 'backup_core').$frm->label(DBLAN_9, 'db_execute', 'backup_core')."
</td>
</tr>
<!-- VERIFY SQL -->
<tr>
<td>".DBLAN_35."</td>
<td>
".$frm->radio('db_execute', 'verify_sql_record').$frm->label(DBLAN_36, 'db_execute', 'verify_sql_record')."
</td>
</tr>
<!-- IMPORT PREFS -->
<tr>
<td>".DBLAN_59."</td>
<td>
".$frm->radio('db_execute', 'importCorePrefsForm').$frm->label(DBLAN_59, 'db_execute', 'importCorePrefsForm')."
</td>
</tr>
<!-- EXPORT PREFS -->
<tr>
<td>".DBLAN_58."</td>
<td>
".$frm->radio('db_execute', 'exportForm').$frm->label(DBLAN_58, 'db_execute', 'exportForm')."
</td>
</tr>
<!-- SCAN SC OVERRIDE -->
<tr>
<td>".DBLAN_55."</td>
<td>
".$frm->radio('db_execute', 'sc_override_scan').$frm->label(DBLAN_56, 'db_execute', 'sc_override_scan')."
</td>
</tr>
</tbody>
</table>
<div class='buttons-bar center'>
".$frm->admin_button('trigger_db_execute', DBLAN_51, 'execute')."
</div>
</fieldset>
</form>
";
$e107->ns->tablerender(DBLAN_10, $emessage->render().$text);
function exportXmlForm()
{
global $frm;
$text = "<form method='post' action='".e_SELF."' id='core-db-export'>
<fieldset id='core-db-export'>
<legend class='e-hideme'>Export Options</legend>
<table cellpadding='0' cellspacing='0' class='adminlist'>
<colgroup span='2'>
<col style='width: 55%'></col>
<col style='width: 5%'></col>
<col style='width: 40%'></col>
</colgroup>
<thead>
<tr>
<th>Name</th>
<th class='right'>Rows</th>
<th>Select</th>
</tr>
</thead>
<tbody>
<tr>
<td>Core Preferences</td>
<td>&nbsp;</td>
<td>
".$frm->checkbox('xml_core_prefs', '1')."
</td>
</tr>";
$tables = table_list();
foreach($tables as $name=>$count)
{
$text .= "<tr>
<td>Table Data: ".$name." </td>
<td class='right'>$count</td>
<td>
".$frm->checkbox("xml_table[".$name."]", $name)."
</td>
</tr>";
}
$text .="
</tbody>
</table>
<div class='buttons-bar center'>
".$frm->admin_button('exportXmlFile', "Export File", 'exportXmlFile')."
</div>
</fieldset>
</form> ";
e107::getRender()->tablerender("Export Options", $text);
}
function exportXmlFile()
{
//TODO - move export/import functions to own class.
require_once(e_ADMIN."ver.php");
$text = "<?xml version='1.0' encoding='utf-8' ?>\n";
$text .= "<e107Export version='".$e107info['e107_version']."' timestamp='".time()."' >\n";
if(varset($_POST['xml_core_prefs'])) // Export Core Preferences.
{
$pref = e107::getPref();
$text .= "\t<prefs>\n";
foreach($pref as $key=>$val)
{
if(isset($val))
{
$val = is_array($val) ? e107::getArrayStorage()->WriteArray($val) : $val;
$text .= "\t\t<core name='$key'><![CDATA[".$val."]]></core>\n";
}
}
$text .= "\t</prefs>\n";
}
if(varset($_POST['xml_table']))
{
$text .= "\t<database>\n";
foreach($_POST['xml_table'] as $tbl)
{
$eTable= str_replace(MPREFIX,"",$tbl);
e107::getDB()->db_Select($eTable, "*");
$text .= "\t<dbTable name='$eTable'>\n";
while($row = e107::getDB()-> db_Fetch())
{
$text .= "\t\t<item>\n";
foreach($row as $key=>$val)
{
$text .= "\t\t\t<field name='".$key."'><![CDATA[".$val."]]></field>\n";
}
$text .= "\t\t</item>\n";
}
$text .= "\t</dbTable>\n";
}
$text .= "\t</database>\n";
}
$text .= "</e107Export>";
header('Content-type: application/xml', TRUE);
header("Content-disposition: attachment; filename= e107Export_" . date("Y-m-d").".xml");
header("Cache-Control: max-age=30");
header("Pragma: public");
echo $text;
exit;
}
function export_tables($tablename)
{
}
function importCorePrefs()
{
//TODO - Cameron - move to own class and make generic.
// SecretR - structure changes / improvements proposal
// to SecretR - loadXMLfile() is failing and should be able to do all of the default options below in one line of code.
// eg. $xmlArray = e107::getSingleton('xmlClass')->loadXMLfile($_FILES['file_userfile']['tmp_name'][0],'advanced');
$inputXml = file_get_contents($_FILES['file_userfile']['tmp_name'][0]);
e107::getSingleton('xmlClass')->setOptForceArray(true) //force array variable type for simple tags of first level
->setOptValueKey('@value') //the default is value
->setOptAddRoot(false); //include root element in the returned array
$xmlArray = e107::getSingleton('xmlClass')->parseXml($inputXml, false);
if(varset($xmlArray['prefs']['core'])) // Save Core Prefs
{
foreach ($xmlArray['prefs']['core'] as $val)
{
e107::getConfig()->set($val['@attributes']['name'], $val['@value']);
}
e107::getConfig()->save();
}
// TODO - Import of table data.
}
function importCorePrefsForm()
{
//TODO - Fix Core XML class - array returned is incorrect.
// importCorePrefs();
// return;
// Get largest allowable file upload
$frm = e107::getSingleton('e_form');
require_once(e_HANDLER.'upload_handler.php');
$max_file_size = get_user_max_upload();
$text = "
<form enctype='multipart/form-data' method='post' action='".e_SELF."'>
<table cellpadding='0' cellspacing='0' class='adminform'>
<colgroup span='2'>
<col class='col-label' />
<col class='col-control' />
</colgroup>
<tr>
<td>".LAN_UPLOAD."</td>
<td>
<input type='hidden' name='MAX_FILE_SIZE' value='{$max_file_size}' />
<input type='hidden' name='ac' value='".md5(ADMINPWCHANGE)."' />
<input class='tbox' type='file' name='file_userfile[]' size='50' />
</td>
</tr>
</tr>
</table>
<div class='center buttons-bar'>";
$text .= $frm->admin_button('upload', LAN_UPLOAD, 'submit', LAN_UPLOAD);
$text .= "
</div>
</form>\n";
e107::getRender()->tablerender("Import e107 Preferences", $text);
}
function table_list()
{
// grab default language lists.
//TODO - a similar function is in db_verify.php. Should probably all be moved to mysql_class.php.
global $mySQLdefaultdb;
$exclude = array();
$exclude[] = "rbinary";
$exclude[] = "parser";
$exclude[] = "tmp";
$exclude[] = "online";
$exclude[] = "upload";
$exclude[] = "user_extended_country";
/*
$exclude[] = "banlist"; $exclude[] = "banner";
$exclude[] = "cache"; $exclude[] = "core";
$exclude[] = "plugin"; $exclude[] = "user";
$exclude[] = "userclass_classes";
$exclude[] = "session";
$exclude[] = "flood";
$exclude[] = "stat_info"; $exclude[] = "stat_last";
$exclude[] = "submit_news"; $exclude[] = "rate";
$exclude[] = "stat_counter";$exclude[] = "user_extended";
$exclude[] = "user_extended_struc";
*/
$tables = mysql_list_tables($mySQLdefaultdb);
while (list($temp) = mysql_fetch_array($tables))
{
e107::getDB()->db_Rows();
$t = mysql_query("SELECT * FROM ".$temp);
$e107tab = str_replace(MPREFIX, "", $temp);
$count = mysql_num_rows($t);
if($count && (strpos($temp,$prefix)!==TRUE) && !in_array($e107tab,$exclude))
{
$tabs[$e107tab] = mysql_num_rows($t);
}
$prefix = MPREFIX."lan_";
$match = array();
// if(preg_match('/^'.$prefix.'(.*)/', $temp, $match))
{
$e107tab = str_replace(MPREFIX, "", $temp);
$pos = strrpos($match[1],"_")+1;
$core = substr(str_replace("lan_","",$e107tab),$pos);
// if (str_replace($exclude, "", $e107tab))
// {
// $tabs[$core] = $e107tab;
// }
}
}
return $tabs;
}
function backup_core()
{
global $pref, $sql;
$tmp = base64_encode((serialize($pref)));
if(!$sql->db_Insert("core", "'pref_backup', '{$tmp}' "))
{
$sql->db_Update("core", "e107_value='{$tmp}' WHERE e107_name='pref_backup'");
}
}
function optimizesql($mySQLdefaultdb)
{
global $emessage;
$result = mysql_list_tables($mySQLdefaultdb);
while($row = mysql_fetch_row($result))
{
mysql_query("OPTIMIZE TABLE ".$row[0]);
}
$emessage->add(DBLAN_11." $mySQLdefaultdb ".DBLAN_12, E_MESSAGE_SUCCESS);
}
function scan_override()
{
global $pref, $emessage;
require_once(e_HANDLER.'file_class.php');
$f = new e_file;
$scList = '';
$fList = $f->get_files(e_FILE.'shortcode/override', '\.sc$');
if(count($fList))
{
$tmp = array();
foreach($fList as $file)
{
$tmp[] = strtoupper(substr($file['fname'], 0, -3));
}
$scList = implode(',', $tmp);
unset($tmp);
}
$pref['sc_override'] = $scList;
save_prefs();
$emessage->add(DBLAN_57.':<br />'.$pref['sc_override'], E_MESSAGE_SUCCESS);
}
function plugin_viewscan()
{
$error_messages = array(0 => DBLAN_31, 1 => DBLAN_32, 2 => DBLAN_33, 3 => DBLAN_34);
$error_image = array("integrity_pass.png", "integrity_fail.png", "warning.png", "blank.png");
global $sql, $e107, $emessage, $frm;
require_once (e_HANDLER."plugin_class.php");
$ep = new e107plugin();
$ep->update_plugins_table(); // scan for e_xxx changes and save to plugin table.
$ep->save_addon_prefs(); // generate global e_xxx_list prefs from plugin table.
/* we all are awaiting for PHP5 only support - method chaining...
$emessage->add(DBLAN_22.' - '.DBLAN_23, E_MESSAGE_SUCCESS)
->add("<a href='".e_SELF."'>".DBLAN_13."</a>", E_MESSAGE_SUCCESS)
->add(DBLAN_30);
*/
$emessage->add(DBLAN_23, E_MESSAGE_SUCCESS);
$emessage->add("<a href='".e_SELF."'>".DBLAN_13."</a>", E_MESSAGE_SUCCESS);
$emessage->add(DBLAN_30);
$text = "
<form method='post' action='".e_ADMIN."db.php' id='plug_edit'>
<fieldset id='core-db-plugin-scan'>
<legend class='e-hideme'>".ADLAN_CL_7."</legend>
<table cellpadding='0' cellspacing='0' class='adminlist'>
<colgroup span='4'>
<col style='width: 20%'></col>
<col style='width: 20%'></col>
<col style='width: 35%'></col>
<col style='width: 25%'></col>
</colgroup>
<thead>
<tr>
<th>".DBLAN_24."</th>
<th>".DBLAN_25."</th>
<th>".DBLAN_26."</th>
<th class='center last'>".DBLAN_27."</th>
</tr>
</thead>
<tbody>
";
$sql->db_Select("plugin", "*", "plugin_id !='' order by plugin_path ASC"); // Must order by path to pick up duplicates. (plugin names may change).
$previous = '';
while($row = $sql->db_Fetch())
{
$text .= "
<tr>
<td>".$e107->tp->toHtml($row['plugin_name'], FALSE, "defs,emotes_off")."</td>
<td>".$row['plugin_path']."</td>
<td>";
if(trim($row['plugin_addons']))
{
//XXX - $nl_code = ''; - OLD VAR?
foreach(explode(',', $row['plugin_addons']) as $this_addon)
{
$ret_code = 3; // Default to 'not checked
if((strpos($this_addon, 'e_') === 0) && (substr($this_addon, - 4, 4) != '_sql'))
{
$ret_code = $ep->checkAddon($row['plugin_path'], $this_addon); // See whether spaces before opening tag or after closing tag
}
$text .= "<div class='clear'>";
$text .= "<img class='icon action S16' src='".e_IMAGE_ABS."fileinspector/".$error_image[$ret_code]."' alt='".$error_messages[$ret_code]."' title='".$error_messages[$ret_code]."' />";
$text .= trim($this_addon); // $ret_code - 0=OK, 1=content error, 2=access error
$text .= "</div>";
}
}
$text .= "
</td>
<td class='center'>
";
if($previous == $row['plugin_path'])
{
$delid = $row['plugin_id'];
$delname = $row['plugin_name'];
//Admin delete button
$text .= $frm->admin_button("delplug[{$delid}]", DBLAN_52, 'delete', '', array('title' => LAN_CONFIRMDEL." ID:{$delid} [$delname]"));
//Or maybe image submit? -
//$text .= $frm->submit_image("delplug[{$delid}]", DBLAN_52, 'delete', LAN_CONFIRMDEL." ID:{$delid} [$delname]");
}
else
{
$text .= ($row['plugin_installflag'] == 1) ? DBLAN_27 : " "; // "Installed and not installed";
}
$text .= "
</td>
</tr>
";
$previous = $row['plugin_path'];
}
$text .= "
</tbody>
</table>
</fieldset>
</form>
";
$e107->ns->tablerender(DBLAN_10.' - '.DBLAN_22, $emessage->render().$text);
}
function pref_editor()
{
global $pref, $e107, $emessage, $frm;
ksort($pref);
$text = "
<form method='post' action='".e_ADMIN."db.php' id='pref_edit'>
<fieldset id='core-db-pref-edit'>
<legend class='e-hideme'>".DBLAN_20."</legend>
<table cellpadding='0' cellspacing='0' class='adminlist'>
<colgroup span='4'>
<col style='width: 5%'></col>
<col style='width: 20%'></col>
<col style='width: 70%'></col>
<col style='width: 5%'></col>
</colgroup>
<thead>
<tr>
<th class='center'>".LAN_DELETE."</th>
<th>".DBLAN_17."</th>
<th>".DBLAN_18."</th>
<th class='center last'>".LAN_OPTIONS."</th>
</tr>
</thead>
<tbody>
";
foreach($pref as $key => $val)
{
$ptext = (is_array($val)) ? "<pre>".print_r($val, TRUE)."</pre>" : htmlspecialchars($val, ENT_QUOTES, 'utf-8');
$ptext = $e107->tp->textclean($ptext, 80);
$text .= "
<tr>
<td class='center autocheck e-pointer'>".$frm->checkbox("delpref2[$key]", 1)."</td>
<td>{$key}</td>
<td>{$ptext}</td>
<td class='center'>".$frm->submit_image("delpref[$key]", LAN_DELETE, 'delete', LAN_CONFIRMDEL." [$key]")."</td>
</tr>
";
}
$text .= "
</tbody>
</table>
<div class='buttons-bar center'>
".$frm->admin_button('delpref_checked', DBLAN_21, 'delete')."
".$frm->admin_button('back', DBLAN_13, 'back')."
</div>
</fieldset>
</form>
";
//$text .= "<div style='text-align:center'><a href='".e_SELF."'>".DBLAN_13."</a></div>\n";
$e107->ns->tablerender(DBLAN_10.' - '.DBLAN_20, $emessage->render().$text);
return $text;
}
function del_pref_val()
{
global $pref, $e107cache, $emessage;
$del = array_keys($_POST['delpref']);
$delpref = $del[0];
if($delpref)
{
unset($pref[$delpref]);
$deleted_list .= "<li>".$delpref."</li>";
}
if($_POST['delpref2'])
{
foreach($_POST['delpref2'] as $k => $v)
{
$deleted_list .= "<li>".$k."</li>";
unset($pref[$k]);
}
}
save_prefs();
$emessage->add(LAN_DELETED."<ul>".$deleted_list."</ul>");
$e107cache->clear();
//$e107->ns->tablerender(LAN_DELETED,$message);
}
function delete_plugin_entry()
{
global $sql, $emessage;
$del = array_keys($_POST['delplug']);
if($sql->db_Delete("plugin", "plugin_id='".intval($del[0])."' LIMIT 1"))
{
$emessage->add(LAN_DELETED, E_MESSAGE_SUCCESS);
}
else
{
$emessage->add(LAN_DELETED_FAILED, E_MESSAGE_WARNING);
}
}
function verify_sql_record()
{
global $emessage, $sql, $sql2, $sql3, $frm, $e107, $tp;
$sql = e107::getDb();
$sql2 = e107::getDb('sql2');
$sql3 = e107::getDb('sql3');
$tables = array();
$tables[] = 'rate';
$tables[] = 'comments';
if(isset($_POST['delete_verify_sql_record']))
{
if(!varset($_POST['del_dbrec']))
{
$emessage->add('Nothing to delete', E_MESSAGE_DEBUG);
}
else
{
$msg = "ok, so you want to delete some records? not a problem at all!<br />";
$msg .= "but, since this is still an experimental procedure, i won't actually delete anything<br />";
$msg .= "instead, i will show you the queries that would be performed<br />";
$text .= "<br />";
$emessage->add($msg, E_MESSAGE_DEBUG);
foreach($_POST['del_dbrec'] as $k => $v)
{
if($k == 'rate')
{
$keys = implode(", ", array_keys($v));
$qry .= "DELETE * FROM rate WHERE rate_id IN (".$keys.")<br />";
}
elseif($k == 'comments')
{
$keys = implode(", ", array_keys($v));
$qry .= "DELETE * FROM comments WHERE comment_id IN (".$keys.")<br />";
}
}
$emessage->add($qry, E_MESSAGE_DEBUG);
$emessage->add("<a href='".e_SELF."'>".DBLAN_13."</a>", E_MESSAGE_DEBUG);
}
}
//Nothing selected
if(isset($_POST['check_verify_sql_record']) && (!isset($_POST['table_rate']) && !isset($_POST['table_comments'])))
{
$_POST['check_verify_sql_record'] = '';
unset($_POST['check_verify_sql_record']);
$emessage->add(DBLAN_53, E_MESSAGE_WARNING);
}
if(!isset($_POST['check_verify_sql_record']))
{
//select table to verify
$text = "
<form method='post' action='".e_SELF."'>
<fieldset id='core-db-verify-sql-tables'>
<legend class='e-hideme'>".DBLAN_39."</legend>
<table cellpadding='0' cellspacing='0' class='adminlist'>
<colgroup span='1'>
<col style='width: 100%'></col>
</colgroup>
<thead>
<tr>
<th class='last'>".DBLAN_37."</th>
</tr>
</thead>
<tbody>
";
foreach($tables as $t)
{
$text .= "
<tr>
<td>
".$frm->checkbox('table_'.$t, $t).$frm->label($t, 'table_'.$t, $t)."
</td>
</tr>
";
}
$text .= "
</tbody>
</table>
<div class='buttons-bar center'>
".$frm->admin_button('check_verify_sql_record', DBLAN_38)."
".$frm->admin_button('back', DBLAN_13, 'back')."
</div>
</fieldset>
</form>
";
$e107->ns->tablerender(DBLAN_10.' - '.DBLAN_39, $emessage->render().$text);
}
else
{
//function to sort the results
function verify_sql_record_cmp($a, $b)
{
$orderby = array('type' => 'asc', 'itemid' => 'asc');
$result = 0;
foreach($orderby as $key => $value)
{
if($a[$key] == $b[$key])
continue;
$result = ($a[$key] < $b[$key]) ? - 1 : 1;
if($value == 'desc')
$result = - $result;
break;
}
return $result;
}
//function to display the results
//$err holds the error data
//$ctype holds the tablename
function verify_sql_record_displayresult($err, $ctype)
{
global $frm;
usort($err, 'verify_sql_record_cmp');
$text = "
<fieldset id='core-core-db-verify-sql-records-{$ctype}'>
<legend>".DBLAN_40." ".$ctype."</legend>
<table cellpadding='0' cellspacing='0' class='adminlist'>
<colgroup span='4'>
<col style='width: 20%'></col>
<col style='width: 10%'></col>
<col style='width: 50%'></col>
<col style='width: 20%'></col>
</colgroup>
<thead>
<tr>
<th>".DBLAN_41."</th>
<th>".DBLAN_42."</th>
<th>".DBLAN_43."</th>
<th class='center last'>".DBLAN_44."</th>
</tr>
</thead>
<tbody>
";
if(is_array($err) && !empty($err))
{
foreach($err as $k => $v)
{
$delkey = $v['sqlid'];
$text .= "
<tr>
<td>{$v['type']}</td>
<td>{$v['itemid']}</td>
<td>".($v['table_exist'] ? DBLAN_45 : DBLAN_46)."</td>
<td class='center'>
".$frm->checkbox('del_dbrec['.$ctype.']['.$delkey.'][]', '1').$frm->label(DBLAN_47, 'del_dbrec['.$ctype.']['.$delkey.'][]', '1')."
</td>
</tr>
";
}
}
else
{
$text .= "
<tr>
<td colspan='4'>{$err}</td>
</tr>
";
}
$text .= "
</tbody>
</table>
</fieldset>
";
return $text;
}
function verify_sql_record_gettables()
{
global $sql2;
//array which will hold all db tables
$dbtables = array();
//get all tables in the db
$sql2->db_Select_gen("SHOW TABLES");
while($row2 = $sql2->db_Fetch())
{
$dbtables[] = $row2[0];
}
return $dbtables;
}
$text = "<form method='post' action='".e_SELF.(e_QUERY ? '?'.e_QUERY : '')."'>";
//validate rate table records
if(isset($_POST['table_rate']))
{
$query = "
SELECT r.*
FROM #rate AS r
WHERE r.rate_id!=''
ORDER BY r.rate_table, r.rate_itemid";
$data = array('type' => 'rate', 'table' => 'rate_table', 'itemid' => 'rate_itemid', 'id' => 'rate_id');
if(!$sql->db_Select_gen($query))
{
$text .= verify_sql_record_displayresult(DBLAN_49, $data['type']);
}
else
{
//the master error array
$err = array();
//array which will hold all db tables
$dbtables = verify_sql_record_gettables();
while($row = $sql->db_Fetch())
{
$ctype = $data['type'];
$cid = $row[$data['id']];
$citemid = $row[$data['itemid']];
$ctable = $row[$data['table']];
//if the rate_table is an existing table, we need to do more validation
//else if the rate_table is not an existing table, this is an invalid reference
//FIXME Steve: table is never found without MPREFIX; Multi-language tables?
if(in_array(MPREFIX.$ctable, $dbtables))
{
$sql3->db_Select_gen("SHOW COLUMNS FROM ".MPREFIX.$ctable);
while($row3 = $sql3->db_Fetch())
{
//find the auto_increment field, since that's the most likely key used
if($row3['Extra'] == 'auto_increment')
{
$aif = $row3['Field'];
break;
}
}
//we need to check if the itemid (still) exists in this table
//if the record is not found, this could well be an obsolete record
//if the record is found, we need to keep this record since it's a valid reference
if(!$sql2->db_Select("{$ctable}", "*", "{$aif}='{$citemid}' ORDER BY {$aif} "))
{
$err[] = array('type' => $ctable, 'sqlid' => $cid, 'table' => $ctable, 'itemid' => $citemid, 'table_exist' => TRUE);
}
}
else
{
$err[] = array('type' => $ctable, 'sqlid' => $cid, 'table' => $ctable, 'itemid' => $citemid, 'table_exist' => FALSE);
}
}
$text .= verify_sql_record_displayresult(($err ? $err : DBLAN_54), $ctype);
}
}
//validate comments table records
if(isset($_POST['table_comments']))
{
$query = "
SELECT c.*
FROM #comments AS c
WHERE c.comment_id!=''
ORDER BY c.comment_type, c.comment_item_id";
$data = array('type' => 'comments', 'table' => 'comment_type', 'itemid' => 'comment_item_id', 'id' => 'comment_id');
if(!$sql->db_Select_gen($query))
{
$text .= verify_sql_record_displayresult(DBLAN_49, $data['type']);
}
else
{
//the master error array
$err = array();
//array which will hold all db tables
$dbtables = verify_sql_record_gettables();
//get all e_comment files and variables
require_once (e_HANDLER."comment_class.php");
$cobj = new comment();
$e_comment = $cobj->get_e_comment();
while($row = $sql->db_Fetch())
{
$ctype = $data['type'];
$cid = $row[$data['id']];
$citemid = $row[$data['itemid']];
$ctable = $row[$data['table']];
//for each comment we need to validate the referencing record exists
//we need to check if the itemid (still) exists in this table
//if the record is not found, this could well be an obsolete record
//if the record is found, we need to keep this record since it's a valid reference
// news
if($ctable == "0")
{
if(!$sql2->db_Select("news", "*", "news_id='{$citemid}' "))
{
$err[] = array('type' => 'news', 'sqlid' => $cid, 'table' => $ctable, 'itemid' => $citemid, 'table_exist' => TRUE);
}
// article, review or content page
}
elseif($ctable == "1")
{
// downloads
}
elseif($ctable == "2")
{
if(!$sql2->db_Select("download", "*", "download_id='{$citemid}' "))
{
$err[] = array('type' => 'download', 'sqlid' => $cid, 'table' => $ctable, 'itemid' => $citemid, 'table_exist' => TRUE);
}
// poll
}
elseif($ctable == "4")
{
if(!$sql2->db_Select("polls", "*", "poll_id='{$citemid}' "))
{
$err[] = array('type' => 'polls', 'sqlid' => $cid, 'table' => $ctable, 'itemid' => $citemid, 'table_exist' => TRUE);
}
// userprofile
}
elseif($ctable == "profile")
{
if(!$sql2->db_Select("user", "*", "user_id='{$citemid}' "))
{
$err[] = array('type' => 'user', 'sqlid' => $cid, 'table' => $ctable, 'itemid' => $citemid, 'table_exist' => TRUE);
}
//else if this is a plugin comment
}
elseif(isset($e_comment[$ctable]) && is_array($e_comment[$ctable]))
{
$var = $e_comment[$ctable];
$qryp = '';
//new method must use the 'qry' variable
if(isset($var) && $var['qry'] != '')
{
if($installed = $sql2->db_Select("plugin", "*", "plugin_path = '".$var['plugin_path']."' AND plugin_installflag = '1' "))
{
$qryp = str_replace("{NID}", $citemid, $var['qry']);
if(!$sql2->db_Select_gen($qryp))
{
$err[] = array('type' => $ctable, 'sqlid' => $cid, 'table' => $ctable, 'itemid' => $citemid, 'table_exist' => TRUE);
}
}
//old method
}
else
{
if(!$sql2->db_Select($var['db_table'], $var['db_title'], $var['db_id']." = '{$citemid}' "))
{
$err[] = array('type' => $ctable, 'sqlid' => $cid, 'table' => $ctable, 'itemid' => $citemid, 'table_exist' => TRUE);
}
}
//in all other cases
}
else
{
$err[] = array('type' => $ctable, 'sqlid' => $cid, 'table' => $ctable, 'itemid' => $citemid, 'table_exist' => FALSE);
}
}
$text .= verify_sql_record_displayresult(($err ? $err : DBLAN_54), $ctype);
}
}
$text .= "
<div class='buttons-bar center'>
".$frm->admin_button('delete_verify_sql_record', DBLAN_48, 'delete')."
".$frm->admin_button('verify_sql_record', DBLAN_13, 'back')."
</div>
</form>
";
$e107->ns->tablerender(DBLAN_10.' - '.DBLAN_50, $emessage->render().$text);
}
}
require_once ("footer.php");
/**
* Handle page DOM within the page header
*
* @return string JS source
*/
function headerjs()
{
require_once (e_HANDLER.'js_helper.php');
$ret = "
<script type='text/javascript'>
if(typeof e107Admin == 'undefined') var e107Admin = {}
/**
* OnLoad Init Control
*/
e107Admin.initRules = {
'Helper': true,
'AdminMenu': false
}
</script>
<script type='text/javascript' src='".e_FILE_ABS."jslib/core/admin.js'></script>
";
return $ret;
}
?>