diff --git a/db/db_update.php b/db/db_update.php index 64b3f6ed..948dd719 100644 --- a/db/db_update.php +++ b/db/db_update.php @@ -1,3 +1,149 @@ +<<<<<<< .mine + +// dspanogle 2011-02-04 This is not required since we have removed the system("mysql".. calls to allow Windows servers installs +/* +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("../data/config.inc.php"); +echo "
\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; +} + +//same fix here for mysql 5.1 not truncating the 16 char usernames +$DBUSER=substr($DBUSER,0,16); + +mysql_connect($DBHOST,$DBUSER,$DBPASS); +mysql_select_db($DBNAME); +@mysql_query("SET NAMES latin1"); +$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; +} + +/* 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\n"; + +?> +======= if(!function_exists("system")) { echo "DB Update requires php's system() function to be available\n"; @@ -115,3 +261,4 @@ else echo "\n"; ?> +>>>>>>> .r2501 diff --git a/install2.php b/install2.php index d6eaa004..9184fcb3 100644 --- a/install2.php +++ b/install2.php @@ -1,3 +1,204 @@ +<<<<<<< .mine + +/* + This file is part of the 'Science Fair In A Box' project + SFIAB Website: http://www.sfiab.ca + + Copyright (C) 2005 Sci-Tech Ontario Inc$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"; + // dspanogle 2011-02-04 Use each section of the sql file instead of using system("sql" ... + // For windows ISP servers that do not provide "sql: executable - replace system call. + // system("mysql --default-character-set=latin1 -h$DBHOST -u$DBUSER -p$DBPASS $DBNAME ' . $templine . '\': ' . mysql_error() . '
'); + // Reset temp variable to empty + $templine = ''; + } + } + echo "
"; + } + 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($config['FAIRYEAR']); + } + + echo "\nAll done - updating new DB version to $dbcodeversion\n"; + mysql_query("UPDATE config SET val='$dbcodeversion' WHERE var='DBVERSION' AND year='0'"); + + } + +} +else +{ + echo "ERROR: dbcodeversion and dbdbversion are not defined\n"; +} + +echo "