2014-07-06 13:21:10 +02:00
|
|
|
<?php
|
|
|
|
// +-----------------------------------------------------------------------+
|
|
|
|
// | Piwigo - a PHP based photo gallery |
|
|
|
|
// +-----------------------------------------------------------------------+
|
2016-08-27 21:53:29 +02:00
|
|
|
// | Copyright(C) 2008-2016 Piwigo Team http://piwigo.org |
|
2014-07-06 13:21:10 +02:00
|
|
|
// | 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!");
|
|
|
|
}
|
|
|
|
|
|
|
|
include_once(PHPWG_ROOT_PATH.'admin/include/functions.php');
|
|
|
|
check_status(ACCESS_ADMINISTRATOR);
|
|
|
|
|
|
|
|
$sections = explode('/', $_GET['section'] );
|
|
|
|
for ($i=0; $i<count($sections); $i++)
|
|
|
|
{
|
|
|
|
if (empty($sections[$i]) or $sections[$i]=='..')
|
|
|
|
{
|
|
|
|
unset($sections[$i]);
|
|
|
|
$i--;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
if (count($sections)<2)
|
|
|
|
{
|
|
|
|
die('Invalid plugin URL');
|
|
|
|
}
|
|
|
|
|
|
|
|
$plugin_id = $sections[0];
|
2015-07-05 19:03:18 +02:00
|
|
|
|
|
|
|
if (!preg_match('/^[\w-]+$/', $plugin_id))
|
|
|
|
{
|
|
|
|
die('Invalid plugin identifier');
|
|
|
|
}
|
|
|
|
|
2014-07-06 13:21:10 +02:00
|
|
|
if ( !isset($pwg_loaded_plugins[$plugin_id]) )
|
|
|
|
{
|
|
|
|
die('Invalid URL - plugin '.$plugin_id.' not active');
|
|
|
|
}
|
|
|
|
|
|
|
|
$filename = PHPWG_PLUGINS_PATH.implode('/', $sections);
|
|
|
|
if (is_file($filename))
|
|
|
|
{
|
|
|
|
include_once($filename);
|
|
|
|
}
|
|
|
|
else
|
|
|
|
{
|
|
|
|
die('Missing file '.$filename);
|
|
|
|
}
|
2016-08-27 21:53:29 +02:00
|
|
|
?>
|