source: branches/2.0/upgrade.php @ 4461

Last change on this file since 4461 was 4189, checked in by ddtddt, 15 years ago

[branche 2] add localisation IT/DE/ES

  • Property svn:eol-style set to LF
  • Property svn:keywords set to Author Date Id Revision
File size: 11.6 KB
RevLine 
[1927]1<?php
2// +-----------------------------------------------------------------------+
[2297]3// | Piwigo - a PHP based picture gallery                                  |
4// +-----------------------------------------------------------------------+
[3046]5// | Copyright(C) 2008-2009 Piwigo Team                  http://piwigo.org |
[2297]6// | Copyright(C) 2003-2008 PhpWebGallery Team    http://phpwebgallery.net |
7// | Copyright(C) 2002-2003 Pierrick LE GALL   http://le-gall.net/pierrick |
8// +-----------------------------------------------------------------------+
9// | This program is free software; you can redistribute it and/or modify  |
10// | it under the terms of the GNU General Public License as published by  |
11// | the Free Software Foundation                                          |
12// |                                                                       |
13// | This program is distributed in the hope that it will be useful, but   |
14// | WITHOUT ANY WARRANTY; without even the implied warranty of            |
15// | MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU      |
16// | General Public License for more details.                              |
17// |                                                                       |
18// | You should have received a copy of the GNU General Public License     |
19// | along with this program; if not, write to the Free Software           |
20// | Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA 02111-1307, |
21// | USA.                                                                  |
22// +-----------------------------------------------------------------------+
[1927]23
24define('PHPWG_ROOT_PATH', './');
25
[2864]26// load config file
27$config_file = PHPWG_ROOT_PATH.'include/mysql.inc.php';
28$config_file_contents = @file_get_contents($config_file);
29if ($config_file_contents === false)
[2837]30{
[2864]31  die('Cannot load '.$config_file);
[2837]32}
[2864]33$php_end_tag = strrpos($config_file_contents, '?'.'>');
34if ($php_end_tag === false)
35{
36  die('Cannot find php end tag in '.$config_file);
37}
[2837]38
[1927]39include_once(PHPWG_ROOT_PATH.'include/functions.inc.php');
40include_once(PHPWG_ROOT_PATH.'admin/include/functions.php');
41include_once(PHPWG_ROOT_PATH.'admin/include/functions_upgrade.php');
42
43include(PHPWG_ROOT_PATH.'include/mysql.inc.php');
44include(PHPWG_ROOT_PATH . 'include/config_default.inc.php');
45@include(PHPWG_ROOT_PATH. 'include/config_local.inc.php');
46
[2096]47prepare_conf_upgrade();
[1927]48
49include_once(PHPWG_ROOT_PATH.'include/constants.php');
50define('PREFIX_TABLE', $prefixeTable);
51
52// Database connection
[2512]53mysql_connect( $cfgHote, $cfgUser, $cfgPassword ) or die ( "Could not connect to database server" );
54mysql_select_db( $cfgBase ) or die ( "Could not connect to database" );
55if ( version_compare(mysql_get_server_info(), '4.1.0', '>=')
56    and defined('DB_CHARSET') and DB_CHARSET!='' )
57{
58  pwg_query('SET NAMES "'.DB_CHARSET.'"');
59}
60
[1927]61// +-----------------------------------------------------------------------+
62// |                              functions                                |
63// +-----------------------------------------------------------------------+
64
65/**
66 * list all tables in an array
67 *
68 * @return array
69 */
70function get_tables()
71{
72  $tables = array();
[2290]73
[1927]74  $query = '
75SHOW TABLES
76;';
[2885]77  $result = pwg_query($query);
[1927]78
79  while ($row = mysql_fetch_row($result))
80  {
81    if (preg_match('/^'.PREFIX_TABLE.'/', $row[0]))
82    {
83      array_push($tables, $row[0]);
84    }
85  }
86
87  return $tables;
88}
89
90/**
91 * list all columns of each given table
92 *
93 * @return array of array
94 */
95function get_columns_of($tables)
96{
97  $columns_of = array();
98
99  foreach ($tables as $table)
100  {
101    $query = '
102DESC '.$table.'
103;';
[2885]104    $result = pwg_query($query);
[1927]105
106    $columns_of[$table] = array();
107
108    while ($row = mysql_fetch_row($result))
109    {
110      array_push($columns_of[$table], $row[0]);
111    }
112  }
113
114  return $columns_of;
115}
116
117/**
118 */
119function print_time($message)
120{
121  global $last_time;
[2290]122
[1927]123  $new_time = get_moment();
124  echo '<pre>['.get_elapsed_time($last_time, $new_time).']';
125  echo ' '.$message;
126  echo '</pre>';
127  flush();
128  $last_time = $new_time;
129}
130
131// +-----------------------------------------------------------------------+
132// |                             playing zone                              |
133// +-----------------------------------------------------------------------+
134
135// echo implode('<br>', get_tables());
136// echo '<pre>'; print_r(get_columns_of(get_tables())); echo '</pre>';
137
138// foreach (get_available_upgrade_ids() as $upgrade_id)
139// {
140//   echo $upgrade_id, '<br>';
141// }
142
143// +-----------------------------------------------------------------------+
[2820]144// |                             language                                  |
145// +-----------------------------------------------------------------------+
146if (isset($_GET['language']))
147{
148  $language = strip_tags($_GET['language']);
149}
150else
151{
152  $language = 'en_UK';
153  // Try to get browser language
154  foreach (get_languages('utf-8') as $language_code => $language_name)
155  {
156    if (substr($language_code,0,2) == @substr($_SERVER["HTTP_ACCEPT_LANGUAGE"],0,2))
157    {
158      $language = $language_code;
159      break;
160    }
161  }
162}
163
[3204]164if ('fr_FR' == $language) {
165  define('PHPWG_DOMAIN', 'fr.piwigo.org');
166}
[4189]167else if ('it_IT' == $language) {
168  define('PHPWG_DOMAIN', 'it.piwigo.org');
169}
170else if ('de_DE' == $language) {
171  define('PHPWG_DOMAIN', 'de.piwigo.org');
172}
173else if ('es_ES' == $language) {
174  define('PHPWG_DOMAIN', 'es.piwigo.org');
175}
[3204]176else {
177  define('PHPWG_DOMAIN', 'piwigo.org');
178}
179define('PHPWG_URL', 'http://'.PHPWG_DOMAIN);
180
[2837]181load_language( 'common.lang', '', array('language'=>$language, 'target_charset'=>'utf-8', 'no_fallback' => true) );
182load_language( 'admin.lang', '', array('language'=>$language, 'target_charset'=>'utf-8', 'no_fallback' => true) );
[3204]183load_language( 'install.lang', '', array('language'=>$language, 'target_charset'=>'utf-8', 'no_fallback' => true) );
[2837]184load_language( 'upgrade.lang', '', array('language'=>$language, 'target_charset'=>'utf-8', 'no_fallback' => true) );
[2820]185
[3204]186// check php version
187if (version_compare(PHP_VERSION, REQUIRED_PHP_VERSION, '<'))
188{
189  include(PHPWG_ROOT_PATH.'install/php5_apache_configuration.php');
190}
191
[2820]192// +-----------------------------------------------------------------------+
[1927]193// |                        template initialization                        |
194// +-----------------------------------------------------------------------+
195
[3204]196include( PHPWG_ROOT_PATH .'include/template.class.php');
[2820]197$template = new Template(PHPWG_ROOT_PATH.'admin/template/goto', 'roma');
[1927]198$template->set_filenames(array('upgrade'=>'upgrade.tpl'));
[3204]199$template->assign(array(
200  'RELEASE' => PHPWG_VERSION,
201  'L_UPGRADE_HELP' => sprintf(l10n('install_help'), PHPWG_URL.'/forum'),
202  )
203);
[1927]204
205// +-----------------------------------------------------------------------+
206// |                            upgrade choice                             |
207// +-----------------------------------------------------------------------+
208
[1999]209$tables = get_tables();
210$columns_of = get_columns_of($tables);
211
[2837]212// find the current release
213if (!in_array('param', $columns_of[PREFIX_TABLE.'config']))
[1927]214{
[2837]215  // we're in branch 1.3, important upgrade, isn't it?
216  if (in_array(PREFIX_TABLE.'user_category', $tables))
[1927]217  {
[2837]218    $current_release = '1.3.1';
[1927]219  }
[2837]220  else
[1927]221  {
[2837]222    $current_release = '1.3.0';
[1927]223  }
[2837]224}
225else if (!in_array(PREFIX_TABLE.'user_cache', $tables))
226{
227  $current_release = '1.4.0';
228}
229else if (!in_array(PREFIX_TABLE.'tags', $tables))
230{
231  $current_release = '1.5.0';
232}
[2861]233else if ( !in_array(PREFIX_TABLE.'plugins', $tables) )
[2837]234{
235  if (!in_array('auto_login_key', $columns_of[PREFIX_TABLE.'user_infos']))
[1927]236  {
[2837]237    $current_release = '1.6.0';
[1927]238  }
239  else
240  {
[2837]241    $current_release = '1.6.2';
[1927]242  }
243}
[2837]244else if (!in_array('md5sum', $columns_of[PREFIX_TABLE.'images']))
245{
246  $current_release = '1.7.0';
247}
248else
249{
250  die('No upgrade required, the database structure is up to date');
251}
[1927]252
253// +-----------------------------------------------------------------------+
254// |                            upgrade launch                             |
255// +-----------------------------------------------------------------------+
[2837]256$page['infos'] = array();
257$page['errors'] = array();
[2864]258$mysql_changes = array();
[1927]259
[2837]260if (isset($_POST['username']) and isset($_POST['password']))
[1927]261{
[2837]262  check_upgrade_access_rights($current_release, $_POST['username'], $_POST['password']);
263}
[2254]264
[2837]265if (isset($_POST['submit']) and check_upgrade())
266{
267  $upgrade_file = PHPWG_ROOT_PATH.'install/upgrade_'.$current_release.'.php';
[1927]268  if (is_file($upgrade_file))
269  {
270    $page['upgrade_start'] = get_moment();
271    $conf['die_on_sql_error'] = false;
272    include($upgrade_file);
273
[2864]274    // Something to add in mysql.inc.php?
275    if (!empty($mysql_changes))
276    {
277      $config_file_contents = 
278        substr($config_file_contents, 0, $php_end_tag) . "\r\n"
[2866]279        . implode("\r\n" , $mysql_changes) . "\r\n"
[2864]280        . substr($config_file_contents, $php_end_tag);
281
282      if (!@file_put_contents($config_file, $config_file_contents))
283      {
284        array_push($page['infos'],
285          l10n('in include/mysql.inc.php, before ?>, insert:') . '
[2866]286<p><textarea rows="4" cols="40">'.implode("\r\n" , $mysql_changes).'</textarea></p>'
[2864]287          );
288      }
289    }
290
[2788]291    // Plugins deactivation
292    if (in_array(PREFIX_TABLE.'plugins', $tables))
293    {
[2816]294      deactivate_non_standard_plugins();
[2788]295    }
296
[2102]297    // Create empty local files to avoid log errors
298    create_empty_local_files();
[2254]299
[1927]300    $page['upgrade_end'] = get_moment();
301
[2254]302    $template->assign(
[1927]303      'upgrade',
304      array(
[2837]305        'VERSION' => $current_release,
[1927]306        'TOTAL_TIME' => get_elapsed_time(
307          $page['upgrade_start'],
308          $page['upgrade_end']
309          ),
310        'SQL_TIME' => number_format(
311          $page['queries_time'],
312          3,
313          '.',
314          ' '
315          ).' s',
316        'NB_QUERIES' => $page['count_queries']
317        )
318      );
319
[2820]320    array_push($page['infos'],
321      l10n('perform a maintenance check')
[1927]322      );
323
[3073]324    // Save $page['infos'] in order to restore after maintenance actions
325    $page['infos_sav'] = $page['infos'];
326    $page['infos'] = array();
327
[2811]328    // c13y_upgrade plugin means "check integrity after upgrade", so it
329    // becomes useful just after an upgrade
[2809]330    $query = '
331REPLACE INTO '.PLUGINS_TABLE.'
332  (id, state)
333  VALUES (\'c13y_upgrade\', \'active\')
334;';
335    pwg_query($query);
[2891]336
337    // Delete cache data
338    invalidate_user_cache(true);
339    $template->delete_compiled_templates();
340
341    // Tables Maintenance
[3076]342    // Disabled optimization table for branch 2.0 only
343    //do_maintenance_all_tables();
[2891]344
[3073]345    // Restore $page['infos'] in order to hide informations messages from functions calles
346    // errors messages are not hide
347    $page['infos'] = $page['infos_sav'];
348
[1927]349  }
[2837]350}
351
352// +-----------------------------------------------------------------------+
353// |                          start template output                        |
354// +-----------------------------------------------------------------------+
355else
356{
357  foreach (get_languages('utf-8') as $language_code => $language_name)
[1927]358  {
[2837]359    if ($language == $language_code)
360    {
361      $template->assign('language_selection', $language_code);
362    }
363    $languages_options[$language_code] = $language_name;
[1927]364  }
[2837]365  $template->assign('language_options', $languages_options);
366
367  $template->assign('introduction', array(
368    'CURRENT_RELEASE' => $current_release,
369    'F_ACTION' => 'upgrade.php?language=' . $language));
370
371  if (!check_upgrade())
372  {
373    $template->assign('login', true);
374  }
[1927]375}
376
[2837]377if (count($page['errors']) != 0)
378{
379  $template->assign('errors', $page['errors']);
380}
381
382if (count($page['infos']) != 0)
383{
384  $template->assign('infos', $page['infos']);
385}
386
[1927]387// +-----------------------------------------------------------------------+
388// |                          sending html code                            |
389// +-----------------------------------------------------------------------+
390
391$template->pparse('upgrade');
392?>
Note: See TracBrowser for help on using the repository browser.