science-ation/db/db_update.php
dave 8d1c6e1cd4 Add an option to bypass the actual db version update write to the
database, so for testing the same update can be applied over and over
without needing to update the db.
2010-07-13 03:30:14 +00:00

119 lines
3.7 KiB
PHP

<?
if(!function_exists("system")) {
echo "DB Update requires php's system() function to be available\n";
exit;
}
//include the config.inc.php
//so we have the db connection info
require_once('../data/config.inc.php');
echo "<pre>\n";
if(file_exists("db.code.version.txt")) {
$dbcodeversion_file=file("db.code.version.txt");
$dbcodeversion=trim($dbcodeversion_file[0]);
}
else {
echo "Couldnt load current db.code.version.txt\n";
exit;
}
$skip_dbversion_update = array_key_exists('skip_dbversion_update', $_GET);
mysql_connect($DBHOST,$DBUSER,$DBPASS);
mysql_select_db($DBNAME);
@mysql_query("SET NAMES utf8");
$q=mysql_query("SELECT val FROM config WHERE var='DBVERSION' AND year='0'");
$r=mysql_fetch_object($q);
$dbdbversion=$r->val;
if(!$dbdbversion) {
echo "Couldnt get current db version. Is SFIAB properly installed?\n";
exit;
}
if($dbdbversion>=190) {
//we can only load in the 'system', because when running from here we have no clue what
//conference the script is interested in
//also, FAIRYEAR doesnt exist anymore
/* Load config just in case there's a PHP script that wants it */
$q=mysql_query("SELECT * FROM config WHERE section='system' AND conferences_id=0");
while($r=mysql_fetch_object($q)) $config[$r->var]=$r->val;
}
else {
/* Get the fair year */
$q=mysql_query("SELECT val FROM config WHERE var='FAIRYEAR' AND year='0'");
$r=mysql_fetch_object($q);
$config = array('FAIRYEAR' => $r->val);
/* Load config just in case there's a PHP script that wants it */
$q=mysql_query("SELECT * FROM config WHERE year='{$config['FAIRYEAR']}'");
while($r=mysql_fetch_object($q)) $config[$r->var]=$r->val;
}
require_once("../config_editor.inc.php"); // For config_update_variables()
if($dbcodeversion && $dbdbversion) {
//lets see if they match
if($dbcodeversion == $dbdbversion) {
echo "DB and CODE are all up-to-date. Version: $dbdbversion\n";
exit;
}
else if($dbcodeversion<$dbdbversion) {
echo "ERROR: dbcodeversion<dbdbversion ($dbcodeversion<$dbdbversion). This should not happen!";
exit;
}
else if($dbcodeversion>$dbdbversion) {
echo "DB update requirements detected\n";
echo "Current DB Version: $dbdbversion\n";
echo "Current CODE Version: $dbcodeversion\n";
echo "Updating database from $dbdbversion to $dbcodeversion\n";
for($ver=$dbdbversion+1;$ver<=$dbcodeversion;$ver++) {
if(file_exists("db.update.$ver.php")) {
include("db.update.$ver.php");
}
if(is_callable("db_update_{$ver}_pre")) {
echo "db.update.$ver.php::db_update_{$ver}_pre() exists - running...\n";
call_user_func("db_update_{$ver}_pre");
echo "db.update.$ver.php::db_update_{$ver}_pre() done.\n";
}
if(file_exists("db.update.$ver.sql")) {
echo "db.update.$ver.sql detected - running...\n";
readfile("db.update.$ver.sql");
echo "\n";
system("mysql --default-character-set=utf8 -h$DBHOST -u$DBUSER -p$DBPASS $DBNAME <db.update.$ver.sql");
}
else {
echo "Version $ver SQL update file not found - skipping over\n";
}
if(is_callable("db_update_{$ver}_post")) {
echo "db.update.$ver.php::db_update_{$ver}_post() exists - running...\n";
call_user_func("db_update_{$ver}_post");
echo "db.update.$ver.php::db_update_{$ver}_post() done.\n";
}
}
if($db_update_skip_variables != true) {
echo "\nUpdating Configuration Variables...\n";
config_update_variables();
}
if($skip_dbversion_update) {
echo "\nAll done - skip_dbversion_update specified, NOT updating to DB version to $dbcodeversion\n";
} else {
echo "\nAll done - updating new DB version to $dbcodeversion\n";
mysql_query("UPDATE config SET val='$dbcodeversion' WHERE var='DBVERSION' AND conferences_id='0'");
}
}
}
else {
echo "ERROR: dbcodeversion and dbdbversion are not defined\n";
}
echo "</pre>\n";
?>