source: trunk/upgrade.php @ 29665

Last change on this file since 29665 was 29665, checked in by plg, 10 years ago
  • feature 3142: upgrade script to Piwigo 2.7
  • link to Tour 2_7_0 at the end of upgrade
  • activate plugin Take a Tour by default
  • Property svn:eol-style set to LF
File size: 15.9 KB
Line 
1<?php
2// +-----------------------------------------------------------------------+
3// | Piwigo - a PHP based photo gallery                                    |
4// +-----------------------------------------------------------------------+
5// | Copyright(C) 2008-2014 Piwigo Team                  http://piwigo.org |
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// +-----------------------------------------------------------------------+
23
24define('PHPWG_ROOT_PATH', './');
25
26// load config file
27include(PHPWG_ROOT_PATH . 'include/config_default.inc.php');
28@include(PHPWG_ROOT_PATH. 'local/config/config.inc.php');
29defined('PWG_LOCAL_DIR') or define('PWG_LOCAL_DIR', 'local/');
30
31$config_file = PHPWG_ROOT_PATH.PWG_LOCAL_DIR.'config/database.inc.php';
32$config_file_contents = @file_get_contents($config_file);
33if ($config_file_contents === false)
34{
35  die('Cannot load '.$config_file);
36}
37$php_end_tag = strrpos($config_file_contents, '?'.'>');
38if ($php_end_tag === false)
39{
40  die('Cannot find php end tag in '.$config_file);
41}
42
43include($config_file);
44
45// $conf is not used for users tables - define cannot be re-defined
46define('USERS_TABLE', $prefixeTable.'users');
47include_once(PHPWG_ROOT_PATH.'include/constants.php');
48define('PREFIX_TABLE', $prefixeTable);
49define('UPGRADES_PATH', PHPWG_ROOT_PATH.'install/db');
50
51include_once(PHPWG_ROOT_PATH.'include/functions.inc.php');
52include_once(PHPWG_ROOT_PATH.'admin/include/functions.php');
53
54// +-----------------------------------------------------------------------+
55// |                              functions                                |
56// +-----------------------------------------------------------------------+
57
58/**
59 * list all tables in an array
60 *
61 * @return array
62 */
63function get_tables()
64{
65  $tables = array();
66
67  $query = '
68SHOW TABLES
69;';
70  $result = pwg_query($query);
71
72  while ($row = pwg_db_fetch_row($result))
73  {
74    if (preg_match('/^'.PREFIX_TABLE.'/', $row[0]))
75    {
76      $tables[] = $row[0];
77    }
78  }
79
80  return $tables;
81}
82
83/**
84 * list all columns of each given table
85 *
86 * @return array of array
87 */
88function get_columns_of($tables)
89{
90  $columns_of = array();
91
92  foreach ($tables as $table)
93  {
94    $query = '
95DESC '.$table.'
96;';
97    $result = pwg_query($query);
98
99    $columns_of[$table] = array();
100
101    while ($row = pwg_db_fetch_row($result))
102    {
103      $columns_of[$table][] = $row[0];
104    }
105  }
106
107  return $columns_of;
108}
109
110/**
111 */
112function print_time($message)
113{
114  global $last_time;
115
116  $new_time = get_moment();
117  echo '<pre>['.get_elapsed_time($last_time, $new_time).']';
118  echo ' '.$message;
119  echo '</pre>';
120  flush();
121  $last_time = $new_time;
122}
123
124// +-----------------------------------------------------------------------+
125// |                             playing zone                              |
126// +-----------------------------------------------------------------------+
127
128// echo implode('<br>', get_tables());
129// echo '<pre>'; print_r(get_columns_of(get_tables())); echo '</pre>';
130
131// foreach (get_available_upgrade_ids() as $upgrade_id)
132// {
133//   echo $upgrade_id, '<br>';
134// }
135
136// +-----------------------------------------------------------------------+
137// |                             language                                  |
138// +-----------------------------------------------------------------------+
139include(PHPWG_ROOT_PATH . 'admin/include/languages.class.php');
140$languages = new languages('utf-8');
141if (isset($_GET['language']))
142{
143  $language = strip_tags($_GET['language']);
144
145  if (!in_array($language, array_keys($languages->fs_languages)))
146  {
147    $language = PHPWG_DEFAULT_LANGUAGE;
148  }
149}
150else
151{
152  $language = 'en_UK';
153  // Try to get browser language
154  foreach ($languages->fs_languages as $language_code => $fs_language)
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
164if ('fr_FR' == $language) {
165  define('PHPWG_DOMAIN', 'fr.piwigo.org');
166}
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}
176else if ('pl_PL' == $language) {
177  define('PHPWG_DOMAIN', 'pl.piwigo.org');
178}
179else if ('zh_CN' == $language) {
180  define('PHPWG_DOMAIN', 'cn.piwigo.org');
181}
182else if ('hu_HU' == $language) {
183  define('PHPWG_DOMAIN', 'hu.piwigo.org');
184}
185else if ('ru_RU' == $language) {
186  define('PHPWG_DOMAIN', 'ru.piwigo.org');
187}
188else if ('nl_NL' == $language) {
189  define('PHPWG_DOMAIN', 'nl.piwigo.org');
190}
191else if ('tr_TR' == $language) {
192  define('PHPWG_DOMAIN', 'tr.piwigo.org');
193}
194else if ('da_DK' == $language) {
195  define('PHPWG_DOMAIN', 'da.piwigo.org');
196}
197else if ('pt_BR' == $language) {
198  define('PHPWG_DOMAIN', 'br.piwigo.org');
199}
200else {
201  define('PHPWG_DOMAIN', 'piwigo.org');
202}
203define('PHPWG_URL', 'http://'.PHPWG_DOMAIN);
204
205load_language( 'common.lang', '', array('language'=>$language, 'target_charset'=>'utf-8', 'no_fallback' => true) );
206load_language( 'admin.lang', '', array('language'=>$language, 'target_charset'=>'utf-8', 'no_fallback' => true) );
207load_language( 'install.lang', '', array('language'=>$language, 'target_charset'=>'utf-8', 'no_fallback' => true) );
208load_language( 'upgrade.lang', '', array('language'=>$language, 'target_charset'=>'utf-8', 'no_fallback' => true) );
209// check php version
210if (version_compare(PHP_VERSION, REQUIRED_PHP_VERSION, '<'))
211{
212  include(PHPWG_ROOT_PATH.'install/php5_apache_configuration.php');
213}
214
215// +-----------------------------------------------------------------------+
216// |                          database connection                          |
217// +-----------------------------------------------------------------------+
218include_once(PHPWG_ROOT_PATH.'admin/include/functions_upgrade.php');
219include(PHPWG_ROOT_PATH .'include/dblayer/functions_'.$conf['dblayer'].'.inc.php');
220
221upgrade_db_connect();
222pwg_db_check_charset();
223
224list($dbnow) = pwg_db_fetch_row(pwg_query('SELECT NOW();'));
225define('CURRENT_DATE', $dbnow);
226
227// +-----------------------------------------------------------------------+
228// |                        template initialization                        |
229// +-----------------------------------------------------------------------+
230
231$template = new Template(PHPWG_ROOT_PATH.'admin/themes', 'clear');
232$template->set_filenames(array('upgrade'=>'upgrade.tpl'));
233$template->assign(array(
234  'RELEASE' => PHPWG_VERSION,
235  'L_UPGRADE_HELP' => l10n('Need help ? Ask your question on <a href="%s">Piwigo message board</a>.', PHPWG_URL.'/forum'),
236  )
237);
238
239// +-----------------------------------------------------------------------+
240// | Remote sites are not compatible with Piwigo 2.4+                      |
241// +-----------------------------------------------------------------------+
242
243$has_remote_site = false;
244
245$query = 'SELECT galleries_url FROM '.SITES_TABLE.';';
246$result = pwg_query($query);
247while ($row = pwg_db_fetch_assoc($result))
248{
249  if (url_is_remote($row['galleries_url']))
250  {
251    $has_remote_site = true;
252  }
253}
254
255if ($has_remote_site)
256{
257  include_once(PHPWG_ROOT_PATH.'admin/include/updates.class.php');
258  include_once(PHPWG_ROOT_PATH.'admin/include/pclzip.lib.php');
259
260  $page['errors'] = array();
261  $step = 3;
262  updates::upgrade_to('2.3.4', $step, false);
263
264  if (!empty($page['errors']))
265  {
266    echo '<ul>';
267    foreach ($page['errors'] as $error)
268    {
269      echo '<li>'.$error.'</li>';
270    }
271    echo '</ul>';
272  }
273
274  exit();
275}
276
277// +-----------------------------------------------------------------------+
278// |                            upgrade choice                             |
279// +-----------------------------------------------------------------------+
280
281$tables = get_tables();
282$columns_of = get_columns_of($tables);
283
284// find the current release
285if (!in_array('param', $columns_of[PREFIX_TABLE.'config']))
286{
287  // we're in branch 1.3, important upgrade, isn't it?
288  if (in_array(PREFIX_TABLE.'user_category', $tables))
289  {
290    $current_release = '1.3.1';
291  }
292  else
293  {
294    $current_release = '1.3.0';
295  }
296}
297else if (!in_array(PREFIX_TABLE.'user_cache', $tables))
298{
299  $current_release = '1.4.0';
300}
301else if (!in_array(PREFIX_TABLE.'tags', $tables))
302{
303  $current_release = '1.5.0';
304}
305else if ( !in_array(PREFIX_TABLE.'plugins', $tables) )
306{
307  if (!in_array('auto_login_key', $columns_of[PREFIX_TABLE.'user_infos']))
308  {
309    $current_release = '1.6.0';
310  }
311  else
312  {
313    $current_release = '1.6.2';
314  }
315}
316else if (!in_array('md5sum', $columns_of[PREFIX_TABLE.'images']))
317{
318  $current_release = '1.7.0';
319}
320else if (!in_array(PREFIX_TABLE.'themes', $tables))
321{
322  $current_release = '2.0.0';
323}
324else if (!in_array('added_by', $columns_of[PREFIX_TABLE.'images']))
325{
326  $current_release = '2.1.0';
327}
328else if (!in_array('rating_score', $columns_of[PREFIX_TABLE.'images']))
329{
330  $current_release = '2.2.0';
331}
332else if (!in_array('rotation', $columns_of[PREFIX_TABLE.'images']))
333{
334  $current_release = '2.3.0';
335}
336else if (!in_array('website_url', $columns_of[PREFIX_TABLE.'comments']))
337{
338  $current_release = '2.4.0';
339}
340else if (!in_array('nb_available_tags', $columns_of[PREFIX_TABLE.'user_cache']))
341{
342  $current_release = '2.5.0';
343}
344else
345{
346  // retrieve already applied upgrades
347  $query = '
348SELECT id
349  FROM '.PREFIX_TABLE.'upgrade
350;';
351  $applied_upgrades = array_from_query($query, 'id');
352
353  if (!in_array(144, $applied_upgrades))
354  {
355    $current_release = '2.6.0';
356  }
357  else
358  {
359    // confirm that the database is in the same version as source code files
360    conf_update_param('piwigo_db_version', get_branch_from_version(PHPWG_VERSION));
361
362    header('Content-Type: text/html; charset='.get_pwg_charset());
363    echo 'No upgrade required, the database structure is up to date';
364    echo '<br><a href="index.php">← back to gallery</a>';
365    exit();
366  }
367}
368
369// +-----------------------------------------------------------------------+
370// |                            upgrade launch                             |
371// +-----------------------------------------------------------------------+
372$page['infos'] = array();
373$page['errors'] = array();
374$mysql_changes = array();
375
376check_upgrade_access_rights();
377
378if ((isset($_POST['submit']) or isset($_GET['now']))
379  and check_upgrade())
380{
381  $upgrade_file = PHPWG_ROOT_PATH.'install/upgrade_'.$current_release.'.php';
382  if (is_file($upgrade_file))
383  {
384    // reset SQL counters
385    $page['queries_time'] = 0;
386    $page['count_queries'] = 0;
387   
388    $page['upgrade_start'] = get_moment();
389    $conf['die_on_sql_error'] = false;
390    include($upgrade_file);
391    conf_update_param('piwigo_db_version', get_branch_from_version(PHPWG_VERSION));
392
393    // Something to add in database.inc.php?
394    if (!empty($mysql_changes))
395    {
396      $config_file_contents = 
397        substr($config_file_contents, 0, $php_end_tag) . "\r\n"
398        . implode("\r\n" , $mysql_changes) . "\r\n"
399        . substr($config_file_contents, $php_end_tag);
400
401      if (!@file_put_contents($config_file, $config_file_contents))
402      {
403        $page['infos'][] = l10n(
404          'In <i>%s</i>, before <b>?></b>, insert:',
405          PWG_LOCAL_DIR.'config/database.inc.php'
406          )
407        .'<p><textarea rows="4" cols="40">'
408        .implode("\r\n" , $mysql_changes).'</textarea></p>';
409      }
410    }
411
412    // Plugins deactivation
413    if (in_array(PREFIX_TABLE.'plugins', $tables))
414    {
415      deactivate_non_standard_plugins();
416    }
417
418    deactivate_non_standard_themes();
419    deactivate_templates();
420
421    $page['upgrade_end'] = get_moment();
422
423    $template->assign(
424      'upgrade',
425      array(
426        'VERSION' => $current_release,
427        'TOTAL_TIME' => get_elapsed_time(
428          $page['upgrade_start'],
429          $page['upgrade_end']
430          ),
431        'SQL_TIME' => number_format(
432          $page['queries_time'],
433          3,
434          '.',
435          ' '
436          ).' s',
437        'NB_QUERIES' => $page['count_queries']
438        )
439      );
440
441    $page['infos'][] = l10n('Perform a maintenance check in [Administration>Tools>Maintenance] if you encounter any problem.');
442
443    // Save $page['infos'] in order to restore after maintenance actions
444    $page['infos_sav'] = $page['infos'];
445    $page['infos'] = array();
446
447    $query = '
448REPLACE INTO '.PLUGINS_TABLE.'
449  (id, state)
450  VALUES (\'TakeATour\', \'active\')
451;';
452    pwg_query($query);
453
454    $template->assign(
455      array(
456        'button_label' => l10n('Home'),
457        'button_link' => 'index.php',
458        )
459      );
460
461    // if the webmaster has a session, let's give a link to discover new features
462    if (!empty($_SESSION['pwg_uid']))
463    {
464      $version_ = str_replace('.', '_', get_branch_from_version(PHPWG_VERSION).'.0');
465     
466      if (file_exists(PHPWG_PLUGINS_PATH .'TakeATour/tours/'.$version_.'/config.inc.php'))
467      {
468        load_language(
469          'plugin.lang',
470          PHPWG_PLUGINS_PATH.'TakeATour/',
471          array(
472            'language' => $language,
473            'force_fallback'=>'en_UK',
474            )
475          );
476
477        // we need the secret key for get_pwg_token()
478        load_conf_from_db();
479       
480        $template->assign(
481          array(
482            'button_label' => l10n('2_7_0_descrp'), // TODO avoid to update it on each release
483            'button_link' => 'admin.php?submited_tour_path=tours/'.$version_.'&amp;pwg_token='.get_pwg_token(),
484            )
485          );
486      }
487    }
488
489    // Delete cache data
490    invalidate_user_cache(true);
491    $template->delete_compiled_templates();
492
493    // Tables Maintenance
494    do_maintenance_all_tables();
495
496    // Restore $page['infos'] in order to hide informations messages from functions calles
497    // errors messages are not hide
498    $page['infos'] = $page['infos_sav'];
499
500  }
501}
502
503// +-----------------------------------------------------------------------+
504// |                          start template output                        |
505// +-----------------------------------------------------------------------+
506else
507{
508  if (!defined('PWG_CHARSET'))
509  {
510    define('PWG_CHARSET', 'utf-8');
511  }
512
513  include_once(PHPWG_ROOT_PATH.'admin/include/languages.class.php');
514  $languages = new languages();
515 
516  foreach ($languages->fs_languages as $language_code => $fs_language)
517  {
518    if ($language == $language_code)
519    {
520      $template->assign('language_selection', $language_code);
521    }
522    $languages_options[$language_code] = $fs_language['name'];
523  }
524  $template->assign('language_options', $languages_options);
525
526  $template->assign('introduction', array(
527    'CURRENT_RELEASE' => $current_release,
528    'F_ACTION' => 'upgrade.php?language=' . $language));
529
530  if (!check_upgrade())
531  {
532    $template->assign('login', true);
533  }
534}
535
536if (count($page['errors']) != 0)
537{
538  $template->assign('errors', $page['errors']);
539}
540
541if (count($page['infos']) != 0)
542{
543  $template->assign('infos', $page['infos']);
544}
545
546// +-----------------------------------------------------------------------+
547// |                          sending html code                            |
548// +-----------------------------------------------------------------------+
549
550$template->pparse('upgrade');
551?>
Note: See TracBrowser for help on using the repository browser.