mirror of
https://github.com/e107inc/e107.git
synced 2025-01-17 12:48:24 +01:00
115 lines
4.2 KiB
PHP
115 lines
4.2 KiB
PHP
<?php
|
|
/*
|
|
* e107 website system
|
|
*
|
|
* Copyright (C) 2008-2009 e107 Inc (e107.org)
|
|
* Released under the terms and conditions of the
|
|
* GNU General Public License (http://www.gnu.org/licenses/gpl.txt)
|
|
*
|
|
*/
|
|
|
|
require_once(__DIR__.'/../class2.php');
|
|
|
|
if(!getperms("0"))
|
|
{
|
|
e107::redirect('admin');
|
|
exit;
|
|
}
|
|
|
|
e107::coreLan('phpinfo', true);
|
|
|
|
$e_sub_cat = 'phpinfo';
|
|
require_once("auth.php");
|
|
|
|
ob_start();
|
|
phpinfo();
|
|
$phpinfo = ob_get_contents();
|
|
|
|
$phpinfo = preg_replace("#^.*<body>#is", "", $phpinfo);
|
|
$phpinfo = str_replace("font","span",$phpinfo);
|
|
$phpinfo = str_replace("</body></html>","",$phpinfo);
|
|
$phpinfo = str_replace('border="0"','',$phpinfo);
|
|
//$phpinfo = str_replace('<table ','<table class="table table-striped adminlist" ',$phpinfo);
|
|
$phpinfo = str_replace('name=','id=',$phpinfo);
|
|
$phpinfo = str_replace('class="e"','class="forumheader2 text-left"',$phpinfo);
|
|
$phpinfo = str_replace('class="v"','class="forumheader3 text-left"',$phpinfo);
|
|
$phpinfo = str_replace('class="v"','class="forumheader3 text-left"',$phpinfo);
|
|
$phpinfo = str_replace('class="h"','class="fcaption"',$phpinfo);
|
|
$phpinfo = preg_replace('/<table[^>]*>/i', '<table class="table table-striped adminlist"><colgroup><col style="width:30%" /><col style="width:auto" /></colgroup>', $phpinfo);
|
|
|
|
|
|
$mes = e107::getMessage();
|
|
|
|
$extensionCheck = array(
|
|
'curl' => array('label'=> 'Curl Library', 'status' => function_exists('curl_version'), 'url'=> 'http://php.net/manual/en/book.curl.php'),
|
|
'exif' => array('label'=> "EXIF Extension", 'status' => function_exists('exif_imagetype'), 'url'=> 'http://php.net/manual/en/book.exif.php'),
|
|
'fileinfo' => array('label'=> "FileInfo. Extension", 'status' => extension_loaded('fileinfo'), 'url'=> 'https://www.php.net/manual/en/book.fileinfo'),
|
|
'gd' => array('label'=> 'GD Library', 'status' => function_exists('gd_info'), 'url'=> 'http://php.net/manual/en/book.image.php'),
|
|
'mb' => array('label'=> 'MB String Library', 'status' => extension_loaded('mbstring'), 'url'=> 'http://php.net/manual/en/book.mbstring.php'),
|
|
'pdo' => array('label'=> "PDO (MySQL)", 'status' => extension_loaded('pdo_mysql'), 'url'=> 'https://php.net/manual/en/book.pdo.php'),
|
|
'xml' => array('label'=> "XML Extension", 'status' => function_exists('utf8_encode') && class_exists('DOMDocument', false), 'url'=> 'http://php.net/manual/en/ref.xml.php'),
|
|
);
|
|
|
|
|
|
|
|
|
|
foreach($extensionCheck as $var)
|
|
{
|
|
if($var['status'] !== true)
|
|
{
|
|
$erTitle = deftrue('PHP_LAN_7', "PHP Configuration Issue(s) Found:");
|
|
$def = deftrue('PHP_LAN_8', "[x] is missing from the PHP configuration and needs to be installed.");
|
|
$message = e107::getParser()->lanVars($def,$var['label'],true);
|
|
|
|
$mes->setIcon('fa-hand-stop-o', E_MESSAGE_ERROR)->setTitle($erTitle,E_MESSAGE_ERROR)->addError($message." <a class='alert-link' href='".$var['url']."' target='_blank' title=\"".$var['url']."\">".ADMIN_INFO_ICON."</a> ");
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
$security_risks = array(
|
|
"allow_url_fopen" => PHP_LAN_1,
|
|
"allow_url_include" => PHP_LAN_2,
|
|
"display_errors" => PHP_LAN_3,
|
|
"expose_php" => PHP_LAN_4,
|
|
"register_globals" => PHP_LAN_5
|
|
);
|
|
|
|
foreach($security_risks as $risk=>$diz)
|
|
{
|
|
if(ini_get($risk))
|
|
{
|
|
$srch = '<tr><td class="forumheader2 text-left">'.$risk.'</td><td class="forumheader3">';
|
|
$repl = '<tr><td class="forumheader2 text-left">'.$risk.'</td><td title="'.e107::getParser()->toAttribute($diz).'" class="forumheader3 alert alert-danger">';
|
|
$phpinfo = str_replace($srch,$repl,$phpinfo);
|
|
$mes->addWarning("<b>".$risk."</b>: ".$diz);
|
|
}
|
|
}
|
|
|
|
$sessionSaveMethod = ini_get('session.save_handler');
|
|
|
|
if($sessionSavePath = ini_get('session.save_path'))
|
|
{
|
|
if(!is_writable($sessionSavePath) && $sessionSaveMethod === 'files')
|
|
{
|
|
$mes->addError(e107::getParser()->toHTML(PHP_LAN_6, true));
|
|
}
|
|
}
|
|
|
|
|
|
// $phpinfo = preg_replace("#^.*<body>#is", "", $phpinfo);
|
|
ob_end_clean();
|
|
|
|
|
|
|
|
if(deftrue('e_DEBUG'))
|
|
{
|
|
$mes->addDebug("Session ID: ".session_id());
|
|
}
|
|
|
|
e107::getRender()->tablerender("PHPInfo", $mes->render(). $phpinfo);
|
|
require_once("footer.php");
|
|
|