diff options
Diffstat (limited to '')
-rw-r--r-- | admin/plugins_new.php | 132 |
1 files changed, 132 insertions, 0 deletions
diff --git a/admin/plugins_new.php b/admin/plugins_new.php new file mode 100644 index 000000000..f7fc21a75 --- /dev/null +++ b/admin/plugins_new.php @@ -0,0 +1,132 @@ +<?php +// +-----------------------------------------------------------------------+ +// | PhpWebGallery - a PHP based picture gallery | +// | Copyright (C) 2003-2007 PhpWebGallery Team - http://phpwebgallery.net | +// +-----------------------------------------------------------------------+ +// | file : $Id$ +// | last update : $Date$ +// | last modifier : $Author$ +// | revision : $Revision$ +// +-----------------------------------------------------------------------+ +// | 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!"); +} + +$template->set_filenames(array('plugins' => 'admin/plugins_new.tpl')); + + +//------------------------------------------------------automatic installation +if (isset($_GET['install']) and isset($_GET['extension']) and !is_adviser()) +{ + include(PHPWG_ROOT_PATH.'admin/include/pclzip.lib.php'); + + $install_status = extract_plugin_files('install', + $_GET['install'], + $_GET['extension']); + + redirect($my_base_url . '&installstatus=' . $install_status); +} + + +//--------------------------------------------------------------install result +if (isset($_GET['installstatus'])) +{ + switch ($_GET['installstatus']) + { + case 'ok': + array_push($page['infos'], l10n('plugins_install_ok'), l10n('plugins_install_need_activate')); + break; + + case 'temp_path_error': + array_push($page['errors'], l10n('plugins_temp_path_error')); + break; + + case 'dl_archive_error': + array_push($page['errors'], l10n('plugins_dl_archive_error')); + break; + + case 'archive_error': + array_push($page['errors'], l10n('plugins_archive_error')); + break; + + default: + array_push($page['errors'], sprintf(l10n('plugins_extract_error'), $_GET['installstatus']), l10n('plugins_check_chmod')); + } +} + + +//----------------------------------------------------------------sort options +$order = isset($_GET['order']) ? $_GET['order'] : 'date'; + +$template->assign('order', + array(htmlentities($my_base_url.'&order=date') => l10n('Post date'), + htmlentities($my_base_url.'&order=name') => l10n('Name'), + htmlentities($my_base_url.'&order=author') => l10n('Author'))); + +$template->assign('selected', htmlentities($my_base_url.'&order=').$order); + + +// +-----------------------------------------------------------------------+ +// | start template output | +// +-----------------------------------------------------------------------+ +$plugins_infos = check_server_plugins(true); +if ($plugins_infos !== false) +{ + if ($order == 'date') krsort($plugins_infos); + else uasort($plugins_infos, 'extension_'.$order.'_compare'); + + foreach($plugins_infos as $plugin) + { + $ext_desc = nl2br(htmlspecialchars(strip_tags( + utf8_encode($plugin['ext_description'])))); + + $ver_desc = sprintf(l10n('plugins_description'), + $plugin['version'], + date('Y-m-d', $plugin['date']), + nl2br(htmlspecialchars(strip_tags( + utf8_encode($plugin['description']))))); + + $url_auto_install = htmlentities($my_base_url) + . '&extension=' . $plugin['id_extension'] + . '&install=%2Fupload%2Fextension-' . $plugin['id_extension'] + . '%2Frevision-' . $plugin['id_revision'] . '%2F' + . str_replace(' ', '%20',$plugin['url']); + + $url_download = PEM_URL .'/upload/extension-'.$plugin['id_extension'] + . '/revision-' . $plugin['id_revision'] + . '/' . $plugin['url']; + + $template->append('plugins', + array('EXT_NAME' => $plugin['ext_name'], + 'EXT_URL' => PEM_URL.'/extension_view.php?eid='.$plugin['id_extension'], + 'EXT_DESC' => $ext_desc, + 'VERSION' => $plugin['version'], + 'VERSION_URL' => PEM_URL.'/revision_view.php?rid='.$plugin['id_revision'], + 'VER_DESC' => $ver_desc, + 'AUTHOR' => $plugin['author'], + 'URL_INSTALL' => $url_auto_install, + 'URL_DOWNLOAD' => $url_download)); + } +} +else +{ + array_push($page['errors'], l10n('plugins_server_error')); +} + +?>
\ No newline at end of file |