2011-02-16 17:00:55 +00:00
|
|
|
<?
|
|
|
|
/*
|
|
|
|
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 <info@scitechontario.org>
|
|
|
|
Copyright (C) 2005 James Grant <james@lightbox.org>
|
|
|
|
|
|
|
|
This program is free software; you can redistribute it and/or
|
|
|
|
modify it under the terms of the GNU General Public
|
|
|
|
License as published by the Free Software Foundation, version 2.
|
|
|
|
|
|
|
|
This program is distributed in the hope that it will be useful,
|
|
|
|
but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
|
|
MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
|
|
|
|
General Public License for more details.
|
|
|
|
|
|
|
|
You should have received a copy of the GNU General Public License
|
|
|
|
along with this program; see the file COPYING. If not, write to
|
|
|
|
the Free Software Foundation, Inc., 59 Temple Place - Suite 330,
|
|
|
|
Boston, MA 02111-1307, USA.
|
|
|
|
*/
|
|
|
|
echo "<?xml version=\"1.0\" encoding=\"iso-8859-1\" ?>\n";
|
|
|
|
?>
|
|
|
|
<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
|
|
|
|
<html xmlns="http://www.w3.org/1999/xhtml" xml:lang="en" >
|
|
|
|
<head><title>SFIAB Installation</title>
|
|
|
|
<link rel="stylesheet" href="sfiab.css" type="text/css" />
|
|
|
|
</head>
|
|
|
|
<body>
|
|
|
|
<h1>SFIAB Installation - Step 2</h1>
|
|
|
|
<?
|
|
|
|
|
|
|
|
if(!function_exists("system")) {
|
|
|
|
echo "<div class=\"error\">Installation requires php's system() function to be available</div>\n";
|
|
|
|
echo "</body></html>";
|
|
|
|
exit;
|
|
|
|
}
|
2011-02-24 18:12:03 +00:00
|
|
|
// Dennis see if mysql is available from cli
|
|
|
|
$exec_sqlstatus = 99; // will be set to 0 if following works. I test this prior to system("mysql...) calls
|
|
|
|
exec("mysql -q --help", $outputnotused, $exec_sqlstatus);
|
2011-02-16 17:00:55 +00:00
|
|
|
|
|
|
|
if(!file_exists("data/config.inc.php"))
|
|
|
|
{
|
|
|
|
echo "<div class=\"error\">SFIAB Installation Step 1 is not yet complete.</div>";
|
|
|
|
echo "<a href=\"install.php\">Go back to installation step 1</a><br />";
|
|
|
|
echo "</body></html>";
|
|
|
|
exit;
|
|
|
|
}
|
|
|
|
|
|
|
|
require_once("data/config.inc.php");
|
|
|
|
$DBUSER=substr($DBUSER,0,16);
|
2024-11-25 23:06:33 +00:00
|
|
|
pdo = new PDO($DBHOST,$DBUSER,$DBPASS);
|
2011-02-16 17:00:55 +00:00
|
|
|
|
|
|
|
echo "Getting database version requirements for code... ";
|
|
|
|
|
|
|
|
if(file_exists("db/db.code.version.txt"))
|
|
|
|
{
|
|
|
|
$dbcodeversion_file=file("db/db.code.version.txt");
|
|
|
|
$dbcodeversion=trim($dbcodeversion_file[0]);
|
|
|
|
}
|
|
|
|
else
|
|
|
|
{
|
|
|
|
echo "<b>ERROR: Couldnt load current db/db.code.version.txt</b><br />";
|
|
|
|
exit;
|
|
|
|
}
|
|
|
|
echo "<b>version $dbcodeversion</b><br />";
|
|
|
|
|
|
|
|
echo "Checking for existing SFIAB database... ";
|
|
|
|
|
2024-11-25 23:06:33 +00:00
|
|
|
$q = $pdo->prepare("SELECT val FROM config WHERE var = 'DBVERSION' AND year = '0'");
|
|
|
|
$q->execute();
|
|
|
|
|
|
|
|
$r = $q->fetch(PDO::FETCH_OBJ);
|
2011-02-16 17:00:55 +00:00
|
|
|
$dbdbversion=$r->val;
|
|
|
|
|
|
|
|
if($dbdbversion)
|
|
|
|
{
|
|
|
|
echo "<b>ERROR: found version $dbdbversion</b><br />";
|
|
|
|
|
|
|
|
//lets see if they match
|
|
|
|
if($dbcodeversion == $dbdbversion)
|
|
|
|
echo "Your SFIAB database is already setup with the required version\n";
|
|
|
|
else if($dbcodeversion<$dbdbversion)
|
|
|
|
echo "ERROR: dbcodeversion<dbdbversion ($dbcodeversion<$dbdbversion). This should not happen!";
|
|
|
|
else if($dbcodeversion>$dbdbversion)
|
|
|
|
echo "Your SFIAB database needs to be updated. You should run the update script instead of this installer!\n";
|
|
|
|
exit;
|
|
|
|
}
|
|
|
|
else
|
|
|
|
{
|
|
|
|
echo "<b>Not found (good!)</b><br />";
|
|
|
|
}
|
2011-02-24 18:12:03 +00:00
|
|
|
// Dennis count the errors here and in db_update
|
|
|
|
$error_count = 0;
|
2011-02-16 17:00:55 +00:00
|
|
|
echo "Checking for database installer for version $dbcodeversion... ";
|
|
|
|
if(file_exists("db/db.full.$dbcodeversion.sql"))
|
|
|
|
{
|
|
|
|
echo "<b>db/db.full.$dbcodeversion.sql found</b><br />";
|
|
|
|
|
|
|
|
echo "Setting up database tables... ";
|
2011-02-24 18:12:03 +00:00
|
|
|
// Dennis If 'system' and 'mysql' do not exist use each section of the sql files not system("sql" ...
|
|
|
|
// i.e. for windows ISP servers that do not provide system and sql.exe executable
|
|
|
|
if(function_exists("system") and $exec_sqlstatus == 0 ) {
|
|
|
|
echo "<b><br />** USING system('mysql ..) on this server!<b><br />";
|
|
|
|
system("mysql --default-character-set=latin1 -h$DBHOST -u$DBUSER -p$DBPASS $DBNAME <db/db.full.$dbcodeversion.sql, $exit_code");
|
|
|
|
}
|
|
|
|
else // 'system' and 'mysql' not available. Try to break up the query and just do each part.
|
|
|
|
{
|
|
|
|
$exit_code = 0;
|
|
|
|
$filename = 'db/db.full.'.$dbcodeversion.'.sql';
|
|
|
|
// Temporary variable, used to store current query
|
|
|
|
$templine = '';
|
|
|
|
// Read in entire file
|
|
|
|
$lines = file($filename);
|
|
|
|
// Loop through each line
|
|
|
|
foreach ($lines as $line)
|
|
|
|
{
|
|
|
|
// Skip it if it's a comment
|
|
|
|
if (substr($line, 0, 2) == '--' || $line == '')
|
|
|
|
continue;
|
|
|
|
// Add this line to the current segment
|
|
|
|
$templine .= $line;
|
|
|
|
// If it has a semicolon at the end, it's the end of the query
|
|
|
|
if (substr(trim($line), -1, 1) == ';')
|
|
|
|
{
|
|
|
|
// Perform the query
|
2024-11-25 23:06:33 +00:00
|
|
|
if(!pdo->exec($templine)){
|
|
|
|
echo('<br/>Error performing query!<br/>'.$templine.'<br/> mysqlerror: '.pdo->errorInfo().'<br /><br />');
|
2011-02-24 18:12:03 +00:00
|
|
|
$exit_code = -1; // do we bail out here or keep going? keep going for now, get all errors
|
|
|
|
}
|
|
|
|
// Reset temp variable to empty
|
|
|
|
$templine = '';
|
|
|
|
}
|
|
|
|
}
|
|
|
|
echo "<br/><br />";
|
|
|
|
}
|
|
|
|
if($exit_code != 0) {
|
|
|
|
/* mysql failed!, what now? */
|
|
|
|
$error_count += 1;
|
|
|
|
echo "<br /><b>mysql failed to execute query(s) without error!<b><br />";
|
|
|
|
}
|
2011-02-16 17:00:55 +00:00
|
|
|
echo "<b>Done! installed database version $dbcodeversion</b><br />\n";
|
|
|
|
|
|
|
|
//now update the db version in the database
|
2024-11-25 23:06:33 +00:00
|
|
|
$stmt = $pdo->prepare("UPDATE config SET val = :dbcodeversion WHERE var = 'DBVERSION' AND year = '0'");
|
|
|
|
$stmt->execute([
|
|
|
|
':dbcodeversion' => $dbcodeversion
|
|
|
|
]);
|
|
|
|
|
2011-02-16 17:00:55 +00:00
|
|
|
|
|
|
|
echo "<br />";
|
|
|
|
echo "<b>Done!</b><br />";
|
2011-02-24 18:12:03 +00:00
|
|
|
// Dennis allert if errors!
|
|
|
|
if ($error_count > 0){
|
|
|
|
echo "<b>THERE WERE ERRORS! The database was not created correctly!</b><br />";
|
|
|
|
}
|
|
|
|
else{
|
|
|
|
echo "<b>DATABASE CREATED SUCCESSFULLY!</b><br />";
|
|
|
|
}
|
2011-02-16 17:00:55 +00:00
|
|
|
echo "<a href=\"install3.php\">Proceed to installation step 3</a><br />";
|
|
|
|
}
|
|
|
|
else
|
|
|
|
{
|
|
|
|
echo "<b>WARNING: Couldnt find db/db.full.$dbcodeversion.sql</b><br />";
|
|
|
|
echo "Trying to find an older version... <br />";
|
|
|
|
|
|
|
|
for($x=$dbcodeversion;$x>0;$x--)
|
2024-11-25 23:06:33 +00:00
|
|
|
{ALTER TABLE `reports_items` ADD `on_overflow` ENUM( 'truncate', '...', 'scale' ) NOT NULL;
|
|
|
|
|
2011-02-16 17:00:55 +00:00
|
|
|
if(file_exists("db/db.full.$x.sql"))
|
|
|
|
{
|
|
|
|
echo "<b>db/db.full.$x.sql found</b><br />";
|
|
|
|
echo "Setting up database tables... ";
|
2011-02-24 18:12:03 +00:00
|
|
|
// Dennis If 'system' and 'mysql' do not exist use each section of the sql files not system("sql"
|
|
|
|
// i.e. for windows ISP servers that do not provide system and sql.exe executable
|
|
|
|
if(function_exists("system") and $exec_sqlstatus == 0 ) {
|
|
|
|
echo "<b><br />** USING system('mysql ..) on this server!<b><br />";
|
|
|
|
system("mysql --default-character-set=latin1 -h$DBHOST -u$DBUSER -p$DBPASS $DBNAME <db/db.full.$x.sql", $exit_code);
|
|
|
|
}
|
|
|
|
else // 'system' and 'mysql' not available. Try to break up the query and just do each part.
|
|
|
|
{
|
|
|
|
$exit_code = 0;
|
|
|
|
$filename = 'db/db.full.'.$x.'.sql';
|
|
|
|
// Temporary variable, used to store current query
|
|
|
|
$templine = '';
|
|
|
|
// Read in entire file
|
|
|
|
$lines = file($filename);
|
|
|
|
// Loop through each line
|
|
|
|
foreach ($lines as $line)
|
|
|
|
{
|
|
|
|
// Skip it if it's a comment
|
|
|
|
if (substr($line, 0, 2) == '--' || $line == '')
|
|
|
|
continue;
|
|
|
|
// Add this line to the current segment
|
|
|
|
$templine .= $line;
|
|
|
|
// If it has a semicolon at the end, it's the end of the query
|
|
|
|
if (substr(trim($line), -1, 1) == ';')
|
|
|
|
{
|
|
|
|
// Perform the query
|
2024-11-25 23:06:33 +00:00
|
|
|
if(!pdo->exec($templine)){
|
|
|
|
echo('<br/>Error performing query!<br/>'.$templine.'<br/> mysqlerror: '.pdo->errorInfo().'<br /><br />');
|
2011-02-24 18:12:03 +00:00
|
|
|
$exit_code = -1; // do we bail out here or keep going? keep going for now, get all errors
|
|
|
|
}
|
|
|
|
// Reset temp variable to empty
|
|
|
|
$templine = '';
|
|
|
|
}
|
|
|
|
}
|
|
|
|
echo "<br/><br />";
|
|
|
|
}
|
|
|
|
if($exit_code != 0) {
|
|
|
|
/* mysql failed!, what now? */
|
|
|
|
$error_count += 1;
|
|
|
|
echo "<br/><b>mysql failed to execute query(s) without error!<b><br/>";
|
|
|
|
}
|
2011-02-16 17:00:55 +00:00
|
|
|
echo "<b>Done! installed database version $x</b><br />\n";
|
|
|
|
|
|
|
|
//now update the db version in the database
|
2024-11-25 23:06:33 +00:00
|
|
|
$stmt = $pdo->prepare("UPDATE config SET val = :x WHERE var = 'DBVERSION' AND year = '0'");$stmt->execute([
|
|
|
|
':x' => $x
|
|
|
|
]);
|
2011-02-16 17:00:55 +00:00
|
|
|
|
|
|
|
echo "<b>Attempting to update database using standard update script to update from $x to $dbcodeversion<br />";
|
|
|
|
echo "<br />Please scroll to the bottom of this page for the link to the next step of the installation process.<br /></b>";
|
|
|
|
chdir ("db");
|
|
|
|
/* Update the database, but don't update the config variables yet, because
|
|
|
|
* We haven't set the FAIRYEAR */
|
|
|
|
$db_update_skip_variables = true;
|
|
|
|
include "db_update.php";
|
|
|
|
chdir ("../");
|
|
|
|
|
|
|
|
echo "<br />";
|
|
|
|
echo "<b>Done!</b><br />";
|
2011-02-24 18:12:03 +00:00
|
|
|
// Dennis allert if errors! 2011-02-18
|
|
|
|
if ($error_count > 0){
|
|
|
|
echo "<b>THERE WERE ERRORS! The database was not created correctly!</b><br />";
|
|
|
|
}
|
|
|
|
else{
|
|
|
|
echo "<b>DATABASE CREATED SUCCESSFULLY!</b><br />";
|
|
|
|
}
|
2011-02-16 17:00:55 +00:00
|
|
|
echo "<a href=\"install3.php\">Proceed to installation step 3</a><br />";
|
|
|
|
break;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
//only if this file was created will we go ahead with the rest
|
|
|
|
//creating all the tables and such..
|
|
|
|
|
|
|
|
?>
|
|
|
|
|
|
|
|
</body></html>
|