librenms/discovery.php

85 lines
2.4 KiB
PHP
Raw Normal View History

#!/usr/bin/php
<?php
include("config.php");
include("includes/functions.php");
$start = utime();
### Observer Device Discovery
echo("Observer v".$config['version']." Discovery\n\n");
if($argv[1] == "--device" && $argv[2]) {
$where = "AND `device_id` = '".$argv[2]."'";
} elseif ($argv[1] == "--os") {
$where = "AND `os` = '".$argv[2]."'";
} elseif ($argv[1] == "--odd") {
$where = "AND MOD(device_id,2) = 1";
} elseif ($argv[1] == "--even") {
$where = "AND MOD(device_id,2) = 0";
} elseif ($argv[1] == "--all") {
$where = "";
} elseif ($argv[1] == "--forced") {
echo("Doing forced discoveries\n");
$sql = mysql_query("SELECT * FROM devices_attribs AS A, `devices` AS D WHERE A.attrib_type = 'discover' AND A.device_id = D.device_id AND D.ignore = '0' AND D.disabled = '0'");
while($device = mysql_fetch_array($sql)){
echo(shell_exec("./discovery.php --device " . $device['device_id']));
}
exit;
} else {
echo("--device <device id> Poll single device\n");
echo("--os <os string> Poll all devices of a given OS\n");
echo("--all Poll all devices\n\n");
echo("No polling type specified!\n");
exit;
}
$devices_polled = 0;
$device_query = mysql_query("SELECT * FROM `devices` WHERE status = '1' $where ORDER BY device_id DESC");
while ($device = mysql_fetch_array($device_query)) {
echo($device['hostname'] ."\n");
## Discover Interfaces
include("includes/discovery/interfaces.php");
## Discover IPv4 Addresses
include("includes/discovery/ipaddresses.php");
## Discovery IPv6 Addresses
include("includes/discovery/ipv6-addresses.php");
## Discover Temperatures
include("includes/discovery/temperatures.php");
if($device['os'] == "Linux" || $device['os'] == "FreeBSD") {
include("includes/discovery/storage.php");
}
if($device['os'] == "Netscreen") {
}
if($device['os'] == "IOS" || $device['os'] == "IOS XE") {
include("includes/discovery/cisco-vlans.php");
include("includes/discovery/cisco-physical.php");
include("includes/discovery/bgp-peers.php");
include("includes/discovery/cisco-pw.php");
include("includes/discovery/cisco-vrf.php");
}
echo("\n"); $devices_polled++;
mysql_query("DELETE FROM `devices_attribs` WHERE `device_id` = '".$device['device_id']."' AND `attrib_type` = 'discover'");
}
$end = utime(); $run = $end - $start;
$proctime = substr($run, 0, 5);
echo("$devices_polled devices polled in $proctime secs\n");
?>