source: trunk/admin.php @ 16308

Last change on this file since 16308 was 15230, checked in by plg, 13 years ago

feature 2606: remove original multiple size configuration screen

  • Property svn:eol-style set to LF
File size: 10.6 KB
RevLine 
[217]1<?php
[354]2// +-----------------------------------------------------------------------+
[8728]3// | Piwigo - a PHP based photo gallery                                    |
[2297]4// +-----------------------------------------------------------------------+
[12922]5// | Copyright(C) 2008-2012 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// +-----------------------------------------------------------------------+
[217]23
[9368]24// +-----------------------------------------------------------------------+
25// | Basic constants and includes                                          |
26// +-----------------------------------------------------------------------+
27
[364]28define('PHPWG_ROOT_PATH','./');
[393]29define('IN_ADMIN', true);
[808]30
[9368]31include_once(PHPWG_ROOT_PATH.'include/common.inc.php');
[1072]32include_once(PHPWG_ROOT_PATH.'admin/include/functions.php');
[1655]33include_once(PHPWG_ROOT_PATH.'admin/include/functions_plugins.inc.php');
[1072]34
[5933]35trigger_action('loc_begin_admin');
36
[808]37// +-----------------------------------------------------------------------+
[1072]38// | Check Access and exit when user status is not ok                      |
39// +-----------------------------------------------------------------------+
[9368]40
[1072]41check_status(ACCESS_ADMINISTRATOR);
42
[9368]43// +-----------------------------------------------------------------------+
44// | Direct actions                                                        |
45// +-----------------------------------------------------------------------+
46
[11222]47// save plugins_new display order (AJAX action)
48if (isset($_GET['plugins_new_order']))
49{
50  pwg_set_session_var('plugins_new_order', $_GET['plugins_new_order']);
51  exit;
52}
53
[5098]54// theme changer
55if (isset($_GET['change_theme']))
56{
[5123]57  $admin_themes = array('roma', 'clear');
[5098]58
59  $new_admin_theme = array_pop(
60    array_diff(
61      $admin_themes,
[5123]62      array($conf['admin_theme'])
[5098]63      )
64    );
65
[5139]66  conf_update_param('admin_theme', $new_admin_theme);
[5098]67
[12102]68  $url_params = array();
69  foreach (array('page', 'tab', 'section') as $url_param)
70  {
71    if (isset($_GET[$url_param]))
72    {
73      $url_params[] = $url_param.'='.$_GET[$url_param];
74    }
75  }
76 
77  $redirect_url = 'admin.php';
78  if (count($url_params) > 0)
79  {
80    $redirect_url.= '?'.implode('&amp;', $url_params);
81  }
82
83  redirect($redirect_url);
[5098]84}
85
[1072]86// +-----------------------------------------------------------------------+
[9368]87// | Synchronize user informations                                         |
[808]88// +-----------------------------------------------------------------------+
[9368]89
[11329]90// sync_user() is only useful when external authentication is activated
91if ($conf['external_authentification'])
[8756]92{
93  sync_users();
94}
[808]95
[817]96// +-----------------------------------------------------------------------+
[9368]97// | Variables init                                                        |
[817]98// +-----------------------------------------------------------------------+
[708]99
[12102]100$change_theme_url = PHPWG_ROOT_PATH.'admin.php?';
101$test_get = $_GET;
102unset($test_get['page']);
103unset($test_get['section']);
104unset($test_get['tag']);
105if (count($test_get) == 0)
106{
107  $change_theme_url.= str_replace('&', '&amp;', $_SERVER['QUERY_STRING']).'&amp;';
108}
109$change_theme_url.= 'change_theme=1';
110
[9357]111// ?page=plugin-community-pendings is an clean alias of
112// ?page=plugin&section=community/admin.php&tab=pendings
[9358]113if (isset($_GET['page']) and preg_match('/^plugin-([^-]*)(?:-(.*))?$/', $_GET['page'], $matches))
[9357]114{
115  $_GET['page'] = 'plugin';
116  $_GET['section'] = $matches[1].'/admin.php';
117  if (isset($matches[2]))
118  {
119    $_GET['tab'] = $matches[2];
120  }
121}
122
[13013]123// ?page=album-134-properties is an clean alias of
124// ?page=album&cat_id=134&tab=properties
125if (isset($_GET['page']) and preg_match('/^album-(\d+)(?:-(.*))?$/', $_GET['page'], $matches))
126{
127  $_GET['page'] = 'album';
128  $_GET['cat_id'] = $matches[1];
129  if (isset($matches[2]))
130  {
131    $_GET['tab'] = $matches[2];
132  }
133}
134
[13077]135// ?page=photo-1234-properties is an clean alias of
136// ?page=photo&image_id=1234&tab=properties
137if (isset($_GET['page']) and preg_match('/^photo-(\d+)(?:-(.*))?$/', $_GET['page'], $matches))
138{
139  $_GET['page'] = 'photo';
140  $_GET['image_id'] = $matches[1];
141  if (isset($matches[2]))
142  {
143    $_GET['tab'] = $matches[2];
144  }
145}
146
[1705]147if (isset($_GET['page'])
[817]148    and preg_match('/^[a-z_]*$/', $_GET['page'])
[1705]149    and is_file(PHPWG_ROOT_PATH.'admin/'.$_GET['page'].'.php'))
[217]150{
[1705]151  $page['page'] = $_GET['page'];
[217]152}
[1705]153else
[217]154{
[1705]155  $page['page'] = 'intro';
[217]156}
[393]157
[1655]158$page['errors'] = array();
159$page['infos']  = array();
[8762]160$page['warnings']  = array();
[1655]161
[8168]162if (isset($_SESSION['page_infos']))
163{
164  $page['infos'] = array_merge($page['infos'], $_SESSION['page_infos']);
165  unset($_SESSION['page_infos']);
166}
167
[393]168$link_start = PHPWG_ROOT_PATH.'admin.php?page=';
[602]169$conf_link = $link_start.'configuration&amp;section=';
[9368]170
171// +-----------------------------------------------------------------------+
172// | Template init                                                         |
173// +-----------------------------------------------------------------------+
174
[2342]175$title = l10n('Piwigo Administration'); // for include/page_header.php
176$page['page_banner'] = '<h1>'.l10n('Piwigo Administration').'</h1>';
[850]177$page['body_id'] = 'theAdminPage';
[393]178
[817]179$template->set_filenames(array('admin' => 'admin.tpl'));
[614]180
[2216]181$template->assign(
[817]182  array(
[5098]183    'USERNAME' => $user['username'],
[6365]184    'ENABLE_SYNCHRONIZATION' => $conf['enable_synchronization'],
[1029]185    'U_SITE_MANAGER'=> $link_start.'site_manager',
[1727]186    'U_HISTORY_STAT'=> $link_start.'stats',
[1004]187    'U_FAQ'=> $link_start.'help',
188    'U_SITES'=> $link_start.'remote_site',
189    'U_MAINTENANCE'=> $link_start.'maintenance',
[1091]190    'U_NOTIFICATION_BY_MAIL'=> $link_start.'notification_by_mail',
[1894]191    'U_CONFIG_GENERAL'=> $link_start.'configuration',
[1004]192    'U_CONFIG_DISPLAY'=> $conf_link.'default',
[2434]193    'U_CONFIG_EXTENTS'=> $link_start.'extend_for_templates',
[2488]194    'U_CONFIG_MENUBAR'=> $link_start.'menubar',
[10594]195    'U_CONFIG_LANGUAGES' => $link_start.'languages',
196    'U_CONFIG_THEMES'=> $link_start.'themes',
[1004]197    'U_CATEGORIES'=> $link_start.'cat_list',
198    'U_CAT_OPTIONS'=> $link_start.'cat_options',
[1058]199    'U_CAT_UPDATE'=> $link_start.'site_update&amp;site=1',
[1042]200    'U_RATING'=> $link_start.'rating',
[8423]201    'U_RECENT_SET'=> $link_start.'batch_manager&amp;cat=recent',
[8394]202    'U_BATCH'=> $link_start.'batch_manager',
[1119]203    'U_TAGS'=> $link_start.'tags',
[1004]204    'U_USERS'=> $link_start.'user_list',
205    'U_GROUPS'=> $link_start.'group_list',
[11368]206    'U_RETURN'=> get_gallery_home_url(),
[2574]207    'U_ADMIN'=> PHPWG_ROOT_PATH.'admin.php',
[3522]208    'U_LOGOUT'=> PHPWG_ROOT_PATH.'index.php?act=logout',
[10594]209    'U_PLUGINS'=> $link_start.'plugins',
[5089]210    'U_ADD_PHOTOS' => $link_start.'photos_add',
[12102]211    'U_CHANGE_THEME' => $change_theme_url,
[10511]212    'U_UPDATES' => $link_start.'updates',
[817]213    )
214  );
[12887]215 
216if ($conf['activate_comments'])
217{
218  $template->assign('U_PENDING_COMMENTS', $link_start.'comments');
219}
[1058]220
[9368]221// +-----------------------------------------------------------------------+
222// | Plugin menu                                                           |
223// +-----------------------------------------------------------------------+
224
[2144]225$plugin_menu_links = trigger_event('get_admin_plugin_menu_links', array() );
226
227function UC_name_compare($a, $b)
228{
229  return strcmp(strtolower($a['NAME']), strtolower($b['NAME']));
230}
231usort($plugin_menu_links, 'UC_name_compare');
[2216]232$template->assign('plugin_menu_items', $plugin_menu_links);
[1655]233
[792]234// +-----------------------------------------------------------------------+
[9368]235// | Refresh permissions                                                   |
[792]236// +-----------------------------------------------------------------------+
[817]237
[1945]238// Only for pages witch change permissions
[1952]239if (
240    in_array($page['page'],
241      array(
242        'site_manager', // delete site
243        'site_update',  // ?only POST
244        'cat_list',     // delete cat
245        'cat_move',     // ?only POST
246        'cat_options',  // ?only POST; public/private; lock/unlock
[2107]247        'picture_modify', // ?only POST; associate/dissociate
[1952]248        'user_perm',
249        'group_perm',
250        'group_list',   // delete group
251      )
252    )
[9127]253    or ( !empty($_POST) and in_array($page['page'],
[8756]254        array(
[13258]255          'photo',
256          'album',        // public/private; lock/unlock, permissions
[8756]257          'batch_manager',  // associate/dissociate; delete; set level
[9127]258          'user_list',    // group assoc; user level
[8756]259        )
260      )
261    )
[1952]262  )
[1945]263{
[1978]264  invalidate_user_cache();
[1945]265}
266
[9368]267// +-----------------------------------------------------------------------+
268// | Include specific page                                                 |
269// +-----------------------------------------------------------------------+
270
[10849]271trigger_action('loc_begin_admin_page');
[9368]272include(PHPWG_ROOT_PATH.'admin/'.$page['page'].'.php');
273
274// +-----------------------------------------------------------------------+
275// | Errors, Infos & Warnings                                              |
276// +-----------------------------------------------------------------------+
277
278$template->assign('ACTIVE_MENU', get_active_menu($page['page']));
279
280if (count($page['errors']) != 0)
281{
282  $template->assign('errors', $page['errors']);
283}
284
285if (count($page['infos']) != 0)
286{
287  $template->assign('infos', $page['infos']);
288}
289
290if (count($page['warnings']) != 0)
291{
292  $template->assign('warnings', $page['warnings']);
293}
294
295// +-----------------------------------------------------------------------+
296// | Sending html code                                                     |
297// +-----------------------------------------------------------------------+
298
299// Add the Piwigo Official menu
300$template->assign( 'pwgmenu', pwg_URL() );
301
302include(PHPWG_ROOT_PATH.'include/page_header.php');
303
304trigger_action('loc_end_admin');
305
306$template->pparse('admin');
307
[1978]308include(PHPWG_ROOT_PATH.'include/page_tail.php');
[362]309?>
Note: See TracBrowser for help on using the repository browser.