mirror of
				https://github.com/librenms/librenms.git
				synced 2024-10-07 16:52:45 +00:00 
			
		
		
		
	git-svn-id: http://www.observium.org/svn/observer/trunk@168 61d68cd4-352d-0410-923a-c4978735b2b8
		
			
				
	
	
		
			33 lines
		
	
	
		
			1.1 KiB
		
	
	
	
		
			PHP
		
	
	
		
			Executable File
		
	
	
	
	
			
		
		
	
	
			33 lines
		
	
	
		
			1.1 KiB
		
	
	
	
		
			PHP
		
	
	
		
			Executable File
		
	
	
	
	
#!/usr/bin/php
 | 
						|
<?php
 | 
						|
 | 
						|
include("config.php");
 | 
						|
include("includes/functions.php");
 | 
						|
 | 
						|
## Check all of our interface RRD files for errors
 | 
						|
 | 
						|
if($argv[1]) { $where = "AND `interface_id` = '$argv[1]'"; }
 | 
						|
 | 
						|
$interface_query = mysql_query("SELECT * FROM `interfaces` AS I, `devices` AS D WHERE I.device_id = D.device_id $where");
 | 
						|
while ($interface = mysql_fetch_array($interface_query)) {
 | 
						|
  $errors = interface_errors($interface);
 | 
						|
  mysql_query("UPDATE `interfaces` SET in_errors = '" . $errors['in'] . "', out_errors = '" . $errors['out'] . "' WHERE interface_id = '" . $interface['interface_id'] . "'");
 | 
						|
  if($errors['in'] > '100' || $errors['out'] > '100') { $errored[] = $interface['hostname'] . " - " . $interface['ifDescr'] . " - " . $interface['ifAlias'] . " - " . $errors['in'] . " - " . $errors['out']; }
 | 
						|
}
 | 
						|
 | 
						|
 | 
						|
if($errored) { ## If there are errored interfaces
 | 
						|
  $i=0;
 | 
						|
  $msg = "Interfaces with errors : \n\n";
 | 
						|
  foreach ($errored as $int) {
 | 
						|
    $msg .= "$int\n";  ## Add a line to the report email warning about them
 | 
						|
    $i++;
 | 
						|
  }
 | 
						|
  
 | 
						|
  ## Send the alert email
 | 
						|
  mail($config['email_default'], "Observer detected errors on $i interfaces", $msg, $config['email_headers']);
 | 
						|
 | 
						|
}
 | 
						|
 | 
						|
?>
 |