2007-03-29 00:06:13 +02:00
|
|
|
<?php
|
|
|
|
// +-----------------------------------------------------------------------+
|
2008-04-05 00:57:23 +02:00
|
|
|
// | Piwigo - a PHP based picture gallery |
|
|
|
|
// +-----------------------------------------------------------------------+
|
|
|
|
// | Copyright(C) 2008 Piwigo Team http://piwigo.org |
|
|
|
|
// | Copyright(C) 2003-2008 PhpWebGallery Team http://phpwebgallery.net |
|
|
|
|
// | Copyright(C) 2002-2003 Pierrick LE GALL http://le-gall.net/pierrick |
|
|
|
|
// +-----------------------------------------------------------------------+
|
|
|
|
// | 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 |
|
|
|
|
// | |
|
|
|
|
// | 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 |
|
2007-03-29 00:06:13 +02:00
|
|
|
// | General Public License for more details. |
|
|
|
|
// | |
|
|
|
|
// | You should have received a copy of the GNU General Public License |
|
|
|
|
// | along with this program; if not, write to the Free Software |
|
|
|
|
// | Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA 02111-1307, |
|
|
|
|
// | USA. |
|
|
|
|
// +-----------------------------------------------------------------------+
|
|
|
|
|
2008-10-15 19:50:12 +02:00
|
|
|
//check php version
|
|
|
|
if (version_compare(PHP_VERSION, '5', '<'))
|
|
|
|
{
|
|
|
|
die('Piwigo requires PHP 5 or above.');
|
|
|
|
}
|
|
|
|
|
2007-03-29 00:06:13 +02:00
|
|
|
define('PHPWG_ROOT_PATH', './');
|
|
|
|
|
|
|
|
include_once(PHPWG_ROOT_PATH.'include/functions.inc.php');
|
|
|
|
include_once(PHPWG_ROOT_PATH.'admin/include/functions.php');
|
|
|
|
include_once(PHPWG_ROOT_PATH.'admin/include/functions_upgrade.php');
|
|
|
|
|
|
|
|
include(PHPWG_ROOT_PATH.'include/mysql.inc.php');
|
|
|
|
include(PHPWG_ROOT_PATH . 'include/config_default.inc.php');
|
|
|
|
@include(PHPWG_ROOT_PATH. 'include/config_local.inc.php');
|
|
|
|
|
|
|
|
check_upgrade();
|
|
|
|
|
2007-09-19 07:26:58 +02:00
|
|
|
prepare_conf_upgrade();
|
2007-03-29 00:06:13 +02:00
|
|
|
|
|
|
|
include_once(PHPWG_ROOT_PATH.'include/constants.php');
|
|
|
|
define('PREFIX_TABLE', $prefixeTable);
|
|
|
|
|
|
|
|
// Database connection
|
2008-09-09 03:16:32 +02:00
|
|
|
mysql_connect( $cfgHote, $cfgUser, $cfgPassword ) or die ( "Could not connect to database server" );
|
|
|
|
mysql_select_db( $cfgBase ) or die ( "Could not connect to database" );
|
|
|
|
if ( version_compare(mysql_get_server_info(), '4.1.0', '>=')
|
|
|
|
and defined('DB_CHARSET') and DB_CHARSET!='' )
|
|
|
|
{
|
|
|
|
pwg_query('SET NAMES "'.DB_CHARSET.'"');
|
|
|
|
}
|
|
|
|
|
2007-03-29 00:06:13 +02:00
|
|
|
// +-----------------------------------------------------------------------+
|
|
|
|
// | tricky output |
|
|
|
|
// +-----------------------------------------------------------------------+
|
|
|
|
echo '<!-- This is an HTML comment given in order to make IE outputs';
|
|
|
|
echo ' the code.'."\n";
|
|
|
|
echo ' Indeed, IE doesn\'t start to send output until a limit';
|
|
|
|
echo ' of XXX bytes '."\n";
|
|
|
|
echo str_repeat( ' ', 80 )."\n";
|
|
|
|
echo str_repeat( ' ', 80 )."\n";
|
|
|
|
echo str_repeat( ' ', 80 )."\n";
|
|
|
|
echo '-->'."\n";
|
|
|
|
flush();
|
|
|
|
// +-----------------------------------------------------------------------+
|
|
|
|
// | functions |
|
|
|
|
// +-----------------------------------------------------------------------+
|
|
|
|
|
|
|
|
/**
|
|
|
|
* list all tables in an array
|
|
|
|
*
|
|
|
|
* @return array
|
|
|
|
*/
|
|
|
|
function get_tables()
|
|
|
|
{
|
|
|
|
$tables = array();
|
2008-03-23 01:04:46 +01:00
|
|
|
|
2007-03-29 00:06:13 +02:00
|
|
|
$query = '
|
|
|
|
SHOW TABLES
|
|
|
|
;';
|
|
|
|
$result = mysql_query($query);
|
|
|
|
|
|
|
|
while ($row = mysql_fetch_row($result))
|
|
|
|
{
|
|
|
|
if (preg_match('/^'.PREFIX_TABLE.'/', $row[0]))
|
|
|
|
{
|
|
|
|
array_push($tables, $row[0]);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
return $tables;
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* list all columns of each given table
|
|
|
|
*
|
|
|
|
* @return array of array
|
|
|
|
*/
|
|
|
|
function get_columns_of($tables)
|
|
|
|
{
|
|
|
|
$columns_of = array();
|
|
|
|
|
|
|
|
foreach ($tables as $table)
|
|
|
|
{
|
|
|
|
$query = '
|
|
|
|
DESC '.$table.'
|
|
|
|
;';
|
|
|
|
$result = mysql_query($query);
|
|
|
|
|
|
|
|
$columns_of[$table] = array();
|
|
|
|
|
|
|
|
while ($row = mysql_fetch_row($result))
|
|
|
|
{
|
|
|
|
array_push($columns_of[$table], $row[0]);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
return $columns_of;
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
*/
|
|
|
|
function print_time($message)
|
|
|
|
{
|
|
|
|
global $last_time;
|
2008-03-23 01:04:46 +01:00
|
|
|
|
2007-03-29 00:06:13 +02:00
|
|
|
$new_time = get_moment();
|
|
|
|
echo '<pre>['.get_elapsed_time($last_time, $new_time).']';
|
|
|
|
echo ' '.$message;
|
|
|
|
echo '</pre>';
|
|
|
|
flush();
|
|
|
|
$last_time = $new_time;
|
|
|
|
}
|
|
|
|
|
|
|
|
// +-----------------------------------------------------------------------+
|
|
|
|
// | playing zone |
|
|
|
|
// +-----------------------------------------------------------------------+
|
|
|
|
|
|
|
|
// echo implode('<br>', get_tables());
|
|
|
|
// echo '<pre>'; print_r(get_columns_of(get_tables())); echo '</pre>';
|
|
|
|
|
|
|
|
// foreach (get_available_upgrade_ids() as $upgrade_id)
|
|
|
|
// {
|
|
|
|
// echo $upgrade_id, '<br>';
|
|
|
|
// }
|
|
|
|
|
|
|
|
// +-----------------------------------------------------------------------+
|
|
|
|
// | template initialization |
|
|
|
|
// +-----------------------------------------------------------------------+
|
|
|
|
|
2008-10-22 01:46:13 +02:00
|
|
|
$template = new Template(PHPWG_ROOT_PATH.'admin/template/goto');
|
2007-03-29 00:06:13 +02:00
|
|
|
$template->set_filenames(array('upgrade'=>'upgrade.tpl'));
|
2008-03-06 01:25:47 +01:00
|
|
|
$template->assign('RELEASE', PHPWG_VERSION);
|
2007-03-29 00:06:13 +02:00
|
|
|
|
|
|
|
// +-----------------------------------------------------------------------+
|
|
|
|
// | upgrade choice |
|
|
|
|
// +-----------------------------------------------------------------------+
|
|
|
|
|
2007-05-04 23:56:58 +02:00
|
|
|
$tables = get_tables();
|
|
|
|
$columns_of = get_columns_of($tables);
|
|
|
|
|
2007-03-29 00:06:13 +02:00
|
|
|
if (!isset($_GET['version']))
|
|
|
|
{
|
|
|
|
// find the current release
|
|
|
|
if (!in_array('param', $columns_of[PREFIX_TABLE.'config']))
|
|
|
|
{
|
|
|
|
// we're in branch 1.3, important upgrade, isn't it?
|
|
|
|
if (in_array(PREFIX_TABLE.'user_category', $tables))
|
|
|
|
{
|
|
|
|
$current_release = '1.3.1';
|
|
|
|
}
|
|
|
|
else
|
|
|
|
{
|
|
|
|
$current_release = '1.3.0';
|
|
|
|
}
|
|
|
|
}
|
|
|
|
else if (!in_array(PREFIX_TABLE.'user_cache', $tables))
|
|
|
|
{
|
|
|
|
$current_release = '1.4.0';
|
|
|
|
}
|
|
|
|
else if (!in_array(PREFIX_TABLE.'tags', $tables))
|
|
|
|
{
|
|
|
|
$current_release = '1.5.0';
|
|
|
|
}
|
2008-03-06 01:25:47 +01:00
|
|
|
else if ( !in_array(PREFIX_TABLE.'history_summary', $tables) )
|
2007-03-29 00:06:13 +02:00
|
|
|
{
|
|
|
|
if (!in_array('auto_login_key', $columns_of[PREFIX_TABLE.'user_infos']))
|
|
|
|
{
|
|
|
|
$current_release = '1.6.0';
|
|
|
|
}
|
|
|
|
else
|
|
|
|
{
|
|
|
|
$current_release = '1.6.2';
|
|
|
|
}
|
|
|
|
}
|
2008-10-17 22:39:30 +02:00
|
|
|
else if (!in_array('md5sum', $columns_of[PREFIX_TABLE.'images']))
|
|
|
|
{
|
|
|
|
$current_release = '1.7.0';
|
|
|
|
}
|
2007-03-29 00:06:13 +02:00
|
|
|
else
|
|
|
|
{
|
|
|
|
die('No upgrade required, the database structure is up to date');
|
|
|
|
}
|
2008-03-23 01:04:46 +01:00
|
|
|
|
2008-03-06 01:25:47 +01:00
|
|
|
$template->assign(
|
2007-03-29 00:06:13 +02:00
|
|
|
'introduction',
|
|
|
|
array(
|
|
|
|
'CURRENT_RELEASE' => $current_release,
|
|
|
|
'RUN_UPGRADE_URL' =>
|
|
|
|
PHPWG_ROOT_PATH.'upgrade.php?version='.$current_release,
|
|
|
|
)
|
|
|
|
);
|
|
|
|
}
|
|
|
|
|
|
|
|
// +-----------------------------------------------------------------------+
|
|
|
|
// | upgrade launch |
|
|
|
|
// +-----------------------------------------------------------------------+
|
|
|
|
|
|
|
|
else
|
|
|
|
{
|
2008-10-17 22:39:30 +02:00
|
|
|
if (in_array('md5sum', $columns_of[PREFIX_TABLE.'images']))
|
2007-05-04 23:56:58 +02:00
|
|
|
{
|
|
|
|
die('No database upgrade required, do not refresh the page');
|
|
|
|
}
|
2008-03-06 01:25:47 +01:00
|
|
|
|
2007-03-29 00:06:13 +02:00
|
|
|
$upgrade_file = PHPWG_ROOT_PATH.'install/upgrade_'.$_GET['version'].'.php';
|
|
|
|
if (is_file($upgrade_file))
|
|
|
|
{
|
|
|
|
$page['infos'] = array();
|
|
|
|
$page['upgrade_start'] = get_moment();
|
|
|
|
$conf['die_on_sql_error'] = false;
|
|
|
|
include($upgrade_file);
|
|
|
|
|
2008-10-22 01:46:13 +02:00
|
|
|
// Plugins deactivation
|
|
|
|
if (in_array(PREFIX_TABLE.'plugins', $tables))
|
|
|
|
{
|
|
|
|
$query = '
|
|
|
|
UPDATE '.PREFIX_TABLE.'plugins SET state="inactive" WHERE state="active"
|
|
|
|
;';
|
|
|
|
mysql_query($query);
|
|
|
|
|
|
|
|
if (mysql_affected_rows() > 0)
|
|
|
|
{
|
|
|
|
array_push(
|
|
|
|
$page['infos'],
|
|
|
|
'As a precaution, all activated plugins have been deactivated.
|
|
|
|
You must check for plugins upgrade before reactiving them.'
|
|
|
|
);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2007-09-21 11:06:00 +02:00
|
|
|
// Create empty local files to avoid log errors
|
|
|
|
create_empty_local_files();
|
2008-03-06 01:25:47 +01:00
|
|
|
|
2007-03-29 00:06:13 +02:00
|
|
|
$page['upgrade_end'] = get_moment();
|
|
|
|
|
2008-03-06 01:25:47 +01:00
|
|
|
$template->assign(
|
2007-03-29 00:06:13 +02:00
|
|
|
'upgrade',
|
|
|
|
array(
|
|
|
|
'VERSION' => $_GET['version'],
|
|
|
|
'TOTAL_TIME' => get_elapsed_time(
|
|
|
|
$page['upgrade_start'],
|
|
|
|
$page['upgrade_end']
|
|
|
|
),
|
|
|
|
'SQL_TIME' => number_format(
|
|
|
|
$page['queries_time'],
|
|
|
|
3,
|
|
|
|
'.',
|
|
|
|
' '
|
|
|
|
).' s',
|
|
|
|
'NB_QUERIES' => $page['count_queries']
|
|
|
|
)
|
|
|
|
);
|
|
|
|
|
|
|
|
array_push(
|
|
|
|
$page['infos'],
|
2007-04-07 17:33:18 +02:00
|
|
|
'[security] delete files "upgrade.php", "upgrade_feed.php", "install.php" and "install"
|
2007-03-29 00:06:13 +02:00
|
|
|
directory'
|
|
|
|
);
|
|
|
|
|
|
|
|
array_push(
|
|
|
|
$page['infos'],
|
|
|
|
'in include/mysql.inc.php, remove
|
|
|
|
<pre style="background-color:lightgray">
|
|
|
|
define(\'PHPWG_IN_UPGRADE\', true);
|
|
|
|
</pre>'
|
|
|
|
);
|
|
|
|
|
|
|
|
array_push(
|
|
|
|
$page['infos'],
|
|
|
|
'Perform a maintenance check in [Administration>General>Maintenance]
|
|
|
|
if you encounter any problem.'
|
|
|
|
);
|
2008-03-23 01:04:46 +01:00
|
|
|
|
2008-03-06 01:25:47 +01:00
|
|
|
$template->assign('infos', $page['infos']);
|
2008-03-23 01:04:46 +01:00
|
|
|
|
2008-10-17 22:39:30 +02:00
|
|
|
invalidate_user_cache();
|
2008-10-25 23:31:30 +02:00
|
|
|
|
2008-10-26 21:44:01 +01:00
|
|
|
// c13y_upgrade plugin means "check integrity after upgrade", so it
|
|
|
|
// becomes useful just after an upgrade
|
2008-10-25 23:31:30 +02:00
|
|
|
$query = '
|
|
|
|
REPLACE INTO '.PLUGINS_TABLE.'
|
|
|
|
(id, state)
|
|
|
|
VALUES (\'c13y_upgrade\', \'active\')
|
|
|
|
;';
|
|
|
|
pwg_query($query);
|
2007-03-29 00:06:13 +02:00
|
|
|
}
|
|
|
|
else
|
|
|
|
{
|
|
|
|
die('Hacking attempt');
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
// +-----------------------------------------------------------------------+
|
|
|
|
// | sending html code |
|
|
|
|
// +-----------------------------------------------------------------------+
|
|
|
|
|
|
|
|
$template->pparse('upgrade');
|
|
|
|
?>
|