add code to allow unauth graphs by IP range, useful for control panels who can use a passthrough (ie php fpassthru) of 'secret' urls, or stats pages, or...

git-svn-id: http://www.observium.org/svn/observer/trunk@1750 61d68cd4-352d-0410-923a-c4978735b2b8
This commit is contained in:
Tom Laermans
2010-12-02 17:41:12 +00:00
parent f71eac502f
commit 76abee7ffa
2 changed files with 79 additions and 50 deletions

View File

@ -1,12 +1,17 @@
<?php
if(isset($_GET['debug'])) {
include_once("Net/IPv4.php");
if (isset($_GET['debug']))
{
$debug = TRUE;
ini_set('display_errors', 1);
ini_set('display_startup_errors', 0);
ini_set('log_errors', 0);
ini_set('error_reporting', E_ALL);
} else {
}
else
{
$debug = FALSE;
ini_set('display_errors', 0);
ini_set('display_startup_errors', 0);
@ -14,52 +19,69 @@ if(isset($_GET['debug'])) {
ini_set('error_reporting', 0);
}
include("../includes/defaults.inc.php");
include("../config.php");
include("../includes/common.php");
include("../includes/rewrites.php");
include("includes/functions.inc.php");
include("includes/authenticate.inc.php");
include("../includes/defaults.inc.php");
include("../config.php");
include("../includes/common.php");
include("../includes/rewrites.php");
include("includes/functions.inc.php");
include("includes/authenticate.inc.php");
$from = mres($_GET['from']);
$to = mres($_GET['to']);
$width = mres($_GET['width']);
$height = mres($_GET['height']);
$title = mres($_GET['title']);
$vertical = mres($_GET['vertical']);
$legend = mres($_GET['legend']);
$id = mres($_GET['id']);
$from = mres($_GET['from']);
$to = mres($_GET['to']);
$width = mres($_GET['width']);
$height = mres($_GET['height']);
$title = mres($_GET['title']);
$vertical = mres($_GET['vertical']);
$legend = mres($_GET['legend']);
$id = mres($_GET['id']);
if($config['allow_unauth_graphs'])
if ($config['allow_unauth_graphs'])
{
$allow_unauth = TRUE;
} else {
if (!$_SESSION['authenticated']) { graph_error("Not authenticated"); exit; }
}
preg_match('/^(?P<type>[A-Za-z0-9]+)_(?P<subtype>.+)/', mres($_GET['type']), $graphtype);
$type = $graphtype['type'];
$subtype = $graphtype['subtype'];
if ($debug) {print_r($graphtype);}
$graphfile = $config['temp_dir'] . "/" . strgen() . ".png";
if (is_file($config['install_dir'] . "/html/includes/graphs/$type/$subtype.inc.php"))
{
if (isset($config['allow_unauth_graphs_cidr']) && count($config['allow_unauth_graphs_cidr']) > 0)
{
$allow_unauth = TRUE;
} else {
if(!$_SESSION['authenticated']) { graph_error("Not authenticated"); exit; }
foreach ($config['allow_unauth_graphs_cidr'] as $range)
{
if (Net_IPv4::ipInNetwork($_SERVER['REMOTE_ADDR'], $range))
{
$auth = TRUE;
}
}
}
preg_match('/^(?P<type>[A-Za-z0-9]+)_(?P<subtype>.+)/', mres($_GET['type']), $graphtype);
$type = $graphtype['type'];
$subtype = $graphtype['subtype'];
if($debug) {print_r($graphtype);}
$graphfile = $config['temp_dir'] . "/" . strgen() . ".png";
if(is_file($config['install_dir'] . "/html/includes/graphs/$type/$subtype.inc.php")) {
include($config['install_dir'] . "/html/includes/graphs/$type/auth.inc.php");
if($auth) {
if (!$auth)
{
include($config['install_dir'] . "/html/includes/graphs/$type/auth.inc.php");
}
if ($auth)
{
include($config['install_dir'] . "/html/includes/graphs/$type/$subtype.inc.php");
}
} else {
}
else
{
graph_error("Graph Template Missing");
}
function graph_error ($string)
function graph_error($string)
{
global $width, $height;
header('Content-type: image/png');
if($height > "99") { $width +=75; }
if ($height > "99") { $width +=75; }
$im = imagecreate($width, $height);
$orange = imagecolorallocate($im, 255, 225, 225);
$px = (imagesx($im) - 7.5 * strlen($string)) / 2;
@ -69,9 +91,9 @@ function graph_error ($string)
exit();
}
if(!$auth)
if (!$auth)
{
if($width < 200)
if ($width < 200)
{
graph_error("No Auth");
} else {
@ -79,35 +101,41 @@ if(!$auth)
}
} else {
#$rrd_options .= " HRULE:0#999999";
if($no_file)
if ($no_file)
{
if($width < 200)
if ($width < 200)
{
graph_error("No RRD");
} else {
graph_error("Missing RRD Datafile");
}
} else {
if($rrd_options)
if ($rrd_options)
{
if($config['rrdcached']) { $rrd_switches = " --daemon ".$config['rrdcached'] . " "; }
if ($config['rrdcached']) { $rrd_switches = " --daemon ".$config['rrdcached'] . " "; }
$rrd_cmd = $config['rrdtool'] . " graph $graphfile $rrd_options" . $rrd_switches;
$woo = shell_exec($rrd_cmd);
if($_GET['debug']) { echo("<pre>".$rrd_cmd."</pre>"); }
if(is_file($graphfile)) {
if ($_GET['debug']) { echo("<pre>".$rrd_cmd."</pre>"); }
if (is_file($graphfile)) {
header('Content-type: image/png');
$fd = fopen($graphfile,'r');fpassthru($fd);fclose($fd);
unlink($graphfile);
} else {
if($width < 200)
}
else
{
if ($width < 200)
{
graph_error("Draw Error");
} else {
}
else
{
graph_error("Error Drawing Graph");
}
}
} else {
if($width < 200)
}
else
{
if ($width < 200)
{
graph_error("Def Error");
} else {
@ -117,4 +145,4 @@ if(!$auth)
}
}
?>
?>

View File

@ -171,6 +171,7 @@ $config['device_traffic_descr'] = array('/loopback/','/vlan/','/tunnel/','/:\d
### Authentication
$config['allow_unauth_graphs'] = 0; ## Allow graphs to be viewed by anyone
$config['allow_unauth_graphs_cidr'] = array(); # Allow graphs to be viewed without authorisation from certain IP ranges
$config['auth_mechanism'] = "mysql"; # Auth Type.
### Sensors