aboutsummaryrefslogtreecommitdiffstats
path: root/install/db/108-database.php
blob: e31aeb17a8d4b991748625f3648adbc7969c1cd1 (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
<?php
// +-----------------------------------------------------------------------+
// | Piwigo - a PHP based photo gallery                                    |
// +-----------------------------------------------------------------------+
// | Copyright(C) 2008-2014 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      |
// | 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.                                                                  |
// +-----------------------------------------------------------------------+

if (!defined('PHPWG_ROOT_PATH'))
{
  die('Hacking attempt!');
}

$upgrade_description = 'add order parameters to bdd #2';

$order_regex = '#^(( *)(id|file|name|date_available|date_creation|hit|average_rate|comment|author|filesize|width|height|high_filesize|high_width|high_height|rank) (ASC|DESC),{1}){1,}$#';

// local file is writable
if ( is_writable($local_file = PHPWG_ROOT_PATH. 'local/config/config.inc.php') )
{
  $order_by = str_ireplace(
    array('order by ', 'asc', 'desc'),
    array(null, 'ASC', 'DESC'),
    trim($conf['order_by_inside_category'])
    );
    
  // for a simple patern
  if ( preg_match($order_regex, $order_by.',') )
  {
    $order_by = 'ORDER BY '.$order_by;
    // update database
    $query = '
    UPDATE '.PREFIX_TABLE.'config
      SET value = \''.preg_replace('# rank (ASC|DESC)(,?)#', null, $order_by).'\'
      WHERE param = \'order_by\'
    ;';
    pwg_query($query);
    $query = '
    UPDATE '.PREFIX_TABLE.'config
      SET value = \''.$order_by.'\'
      WHERE param = \'order_by_inside_category\'
    ';
    pwg_query($query);
    
    // update local file (delete lines)
    $local_config = file($local_file);
    $new_local_config = array();
    foreach ($local_config as $line)
    {
      if (strpos($line, 'order_by') === false)
      {
        $new_local_config[] = $line;
      }
    }
    var_dump($new_local_config);
    file_put_contents(
      $local_file,
      implode("", $new_local_config)
      );
  }
  // for a complex patern
  else
  {
    // update database with default param
    $query = '
    UPDATE '.PREFIX_TABLE.'config
      SET value = \'ORDER BY date_available DESC, file ASC, id ASC\'
      WHERE param = \'order_by\'
    ;';
    pwg_query($query);
    $query = '
    UPDATE '.PREFIX_TABLE.'config
      SET value = \'ORDER BY date_available DESC, file ASC, id ASC\'
      WHERE param = \'order_by_inside_category\'
    ';
    pwg_query($query);
    
    // update local file (rename lines)
    $local_config = file_get_contents($local_file);
    $new_local_config = str_replace(
      array("['order_by']", "['order_by_inside_category']"),
      array("['order_by_custom']", "['order_by_inside_category_custom']"),
      $local_config
      );
    file_put_contents($local_file, $new_local_config);
  }
  
}
// local file is locked
else
{
  // update database with default param
  $query = '
  UPDATE '.PREFIX_TABLE.'config
    SET value = \'ORDER BY date_available DESC, file ASC, id ASC\'
    WHERE param = \'order_by\'
  ;';
  pwg_query($query);
  $query = '
  UPDATE '.PREFIX_TABLE.'config
    SET value = \'ORDER BY date_available DESC, file ASC, id ASC\'
    WHERE param = \'order_by_inside_category\'
  ';
  pwg_query($query);
}

echo
"\n"
. $upgrade_description
."\n"
;
?>