Upgrade improvements (faster checksum, fix database upgrade, prompt on checksum failure).
This commit is contained in:
@@ -160,55 +160,24 @@ class System {
|
||||
return $items;
|
||||
}
|
||||
|
||||
public static function getFilesChecksum($dir, $root = NULL) {
|
||||
if (!isset($root))
|
||||
$root = $dir;
|
||||
$dir = realpath($dir);
|
||||
$root = realpath($root);
|
||||
$items = glob($dir . "/*");
|
||||
$checksums = array();
|
||||
foreach ($items as $item) {
|
||||
$relname = substr($item, strlen($root));
|
||||
//Skip xmlform files, since they always change.
|
||||
if (strpos($relname, "/xmlform/") !== false)
|
||||
continue;
|
||||
//Skip shared and compiled directories.
|
||||
if ((strpos($relname, "/shared") === 0) || (strpos($relname, "/compiled") === 0)) {
|
||||
continue;
|
||||
}
|
||||
if (is_dir($item)) {
|
||||
$checksums = array_merge($checksums, System::getFilesChecksum($item, $root));
|
||||
} else {
|
||||
$checksums[".$relname"] = md5_file($item);
|
||||
}
|
||||
}
|
||||
return $checksums;
|
||||
}
|
||||
|
||||
public static function verifyChecksum() {
|
||||
if (!file_exists(PATH_TRUNK . "checksum.txt"))
|
||||
return false;
|
||||
$filesChecksum = System::getFilesChecksum(PATH_TRUNK);
|
||||
$lines = explode("\n", file_get_contents(PATH_TRUNK . "checksum.txt"));
|
||||
$originalChecksum = array();
|
||||
$result = array("diff" => array(), "missing" => array());
|
||||
foreach ($lines as $line) {
|
||||
if (empty($line))
|
||||
continue;
|
||||
list($checksum, $empty, $filename) = explode(" ", $line);
|
||||
$originalChecksum[$filename] = $checksum;
|
||||
}
|
||||
$result = array("diff" => array(), "missing" => array());
|
||||
foreach ($originalChecksum as $filename => $checksum) {
|
||||
//Skip hidden files that start with a dot.
|
||||
if (substr(basename($filename), 0, 1) === '.')
|
||||
continue;
|
||||
//Skip xmlform files, since they always change.
|
||||
//Skip xmlform because these files always change.
|
||||
if (strpos($filename, "/xmlform/") !== false)
|
||||
continue;
|
||||
if (!array_key_exists($filename, $filesChecksum)) {
|
||||
if (file_exists(realpath($filename))) {
|
||||
if (strcmp($checksum, md5_file(realpath($filename))) != 0) {
|
||||
$result['diff'][] = $filename;
|
||||
}
|
||||
} else {
|
||||
$result['missing'][] = $filename;
|
||||
} else if (strcmp($checksum, $filesChecksum[$filename]) != 0) {
|
||||
$result['diff'][] = $filename;
|
||||
}
|
||||
}
|
||||
return $result;
|
||||
|
||||
@@ -304,12 +304,14 @@ class workspaceTools {
|
||||
public function upgradePluginsDatabase() {
|
||||
foreach (System::getPlugins() as $pluginName) {
|
||||
$pluginSchema = System::getPluginSchema($pluginName);
|
||||
if ($pluginSchema !== false)
|
||||
if ($pluginSchema !== false) {
|
||||
logging("Updating plugin " . info($pluginName) . "\n");
|
||||
$this->upgradeSchema($pluginSchema);
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
public function upgradeDatabase($checkOnly) {
|
||||
public function upgradeDatabase($checkOnly = false) {
|
||||
$systemSchema = System::getSystemSchema();
|
||||
return $this->upgradeSchema($systemSchema);
|
||||
}
|
||||
@@ -484,6 +486,36 @@ class workspaceTools {
|
||||
}
|
||||
}
|
||||
|
||||
public function dumpDatabase($dbname) {
|
||||
$sql="show tables;";
|
||||
$result= mysql_query($sql);
|
||||
if( $result)
|
||||
{
|
||||
while( $row= mysql_fetch_row($result))
|
||||
{
|
||||
$table = $row[0];
|
||||
|
||||
echo "/* Table structure for table `$table` */\n";
|
||||
echo "DROP TABLE IF EXISTS `$table`;\n\n";
|
||||
$sql="show create table `$table`; ";
|
||||
$result=mysql_query($sql);
|
||||
if( $result)
|
||||
{
|
||||
if($row= mysql_fetch_assoc($result))
|
||||
{
|
||||
echo $row['Create Table'].";\n\n";
|
||||
}
|
||||
}
|
||||
|
||||
}
|
||||
}
|
||||
else
|
||||
{
|
||||
echo "/* no tables in $mysql_database */\n";
|
||||
}
|
||||
mysql_free_result($result);
|
||||
}
|
||||
|
||||
public function exportDatabase($path) {
|
||||
$dbInfo = $this->getDBInfo();
|
||||
$databases = array("wf", "rp", "rb");
|
||||
@@ -498,5 +530,28 @@ class workspaceTools {
|
||||
}
|
||||
}
|
||||
|
||||
public function addToBackup($backup, $filename, $root) {
|
||||
if (is_file($filename)) {
|
||||
$backup->addModify($filename, "", $root);
|
||||
} else {
|
||||
foreach (glob($filename . "/*") as $item) {
|
||||
$this->addToBackup($backup, $item, $root);
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
public function backup($filename, $compress = true) {
|
||||
G::LoadThirdParty('pear/Archive', 'Tar');
|
||||
$tar = new Archive_Tar($filename);
|
||||
//Get a temporary directory for database backup
|
||||
$tempDirectory = tempnam(__FILE__, '');
|
||||
if (file_exists($tempDirectory)) {
|
||||
unlink($tempDirectory);
|
||||
}
|
||||
$this->exportDatabase($tempDirectory);
|
||||
$this->addToBackup($backup, $tempDirectory, $tempDirectory);
|
||||
$this->addToBackup($backup, $filename, $root);
|
||||
}
|
||||
|
||||
}
|
||||
?>
|
||||
|
||||
Reference in New Issue
Block a user