source: trunk/admin/plugins_new.php @ 5475

Last change on this file since 5475 was 5406, checked in by patdenice, 14 years ago

Add token to themes installation.
Only webmasters can install new plugins, themes or languages.

  • Property svn:eol-style set to LF
File size: 5.5 KB
Line 
1<?php
2// +-----------------------------------------------------------------------+
3// | Piwigo - a PHP based picture gallery                                  |
4// +-----------------------------------------------------------------------+
5// | Copyright(C) 2008-2010 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
24if( !defined("PHPWG_ROOT_PATH") )
25{
26  die ("Hacking attempt!");
27}
28
29include_once(PHPWG_ROOT_PATH.'admin/include/plugins.class.php');
30
31$template->set_filenames(array('plugins' => 'plugins_new.tpl'));
32
33$order = isset($_GET['order']) ? $_GET['order'] : 'date';
34$base_url = get_root_url().'admin.php?page='.$page['page'].'&order='.$order;
35
36$plugins = new plugins();
37
38//------------------------------------------------------automatic installation
39if (isset($_GET['revision']) and isset($_GET['extension']))
40{
41  if (!is_webmaster())
42  {
43    array_push($page['errors'], l10n('Webmaster status is required.'));
44  }
45  else
46  {
47    check_pwg_token();
48   
49    $install_status = $plugins->extract_plugin_files('install', $_GET['revision'], $_GET['extension']);
50
51    redirect($base_url.'&installstatus='.$install_status);
52  }
53}
54
55//--------------------------------------------------------------install result
56if (isset($_GET['installstatus']))
57{
58  switch ($_GET['installstatus'])
59  {
60    case 'ok':
61      array_push($page['infos'],
62        l10n('Plugin has been successfully copied'),
63        l10n('You might go to plugin list to install and activate it.'));
64      break;
65
66    case 'temp_path_error':
67      array_push($page['errors'], l10n('Can\'t create temporary file.'));
68      break;
69
70    case 'dl_archive_error':
71      array_push($page['errors'], l10n('Can\'t download archive.'));
72      break;
73
74    case 'archive_error':
75      array_push($page['errors'], l10n('Can\'t read or extract archive.'));
76      break;
77
78    default:
79      array_push($page['errors'],
80        sprintf(l10n('An error occured during extraction (%s).'), $_GET['installstatus']),
81        l10n('Please check "plugins" folder and sub-folders permissions (CHMOD).'));
82  } 
83}
84
85//--------------------------------------------------------------------Tabsheet
86$plugins->set_tabsheet($page['page']);
87
88//---------------------------------------------------------------Order options
89$link = get_root_url().'admin.php?page='.$page['page'].'&amp;order=';
90$template->assign('order_options',
91  array(
92    $link.'date' => l10n('Post date'),
93    $link.'revision' => l10n('Last revisions'),
94    $link.'name' => l10n('Name'),
95    $link.'author' => l10n('Author'),
96    $link.'downloads' => l10n('Number of downloads')));
97$template->assign('order_selected', $link.$order);
98
99// +-----------------------------------------------------------------------+
100// |                     start template output                             |
101// +-----------------------------------------------------------------------+
102if ($plugins->get_server_plugins(true))
103{
104  $plugins->sort_server_plugins($order);
105
106  foreach($plugins->server_plugins as $plugin)
107  {
108    list($date, ) = explode(' ', $plugin['revision_date']);
109
110    $ext_desc = '<i>'.l10n('Downloads').':</i> '.$plugin['extension_nb_downloads']."\r\n"
111      ."\r\n"
112      .$plugin['extension_description'];
113
114    $rev_desc = '<i>'.l10n('Version').':</i> '.$plugin['revision_name']."\r\n"
115      .'<i>'.l10n('Released on').':</i> '.$date."\r\n"
116      .'<i>'.l10n('Downloads').':</i> '.$plugin['revision_nb_downloads']."\r\n"
117      ."\r\n"
118      .$plugin['revision_description'];
119
120    $url_auto_install = htmlentities($base_url)
121      . '&amp;revision=' . $plugin['revision_id']
122      . '&amp;extension=' . $plugin['extension_id']
123      . '&amp;pwg_token='.get_pwg_token()
124    ;
125
126    $template->append('plugins', array(
127      'EXT_NAME' => $plugin['extension_name'],
128      'EXT_URL' => PEM_URL.'/extension_view.php?eid='.$plugin['extension_id'],
129      'EXT_DESC' => $ext_desc,
130      'VERSION' => $plugin['revision_name'],
131      'DATE' => $date,
132      'VER_DESC' => $rev_desc,
133      'AUTHOR' => $plugin['author_name'],
134      'URL_INSTALL' => $url_auto_install,
135      'URL_DOWNLOAD' => $plugin['download_url'] . '&amp;origin=piwigo_download'));
136  }
137}
138else
139{
140  array_push($page['errors'], l10n('Can\'t connect to server.'));
141}
142
143$template->assign_var_from_handle('ADMIN_CONTENT', 'plugins');
144?>
Note: See TracBrowser for help on using the repository browser.