| 
									
										
										
										
											2008-03-22 23:09:35 +00:00
										 |  |  | #!/usr/bin/php
 | 
					
						
							|  |  |  | <?php | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | include("config.php"); | 
					
						
							|  |  |  | include("includes/functions.php"); | 
					
						
							| 
									
										
										
										
											2009-11-10 19:28:24 +00:00
										 |  |  | include("includes/functions-poller.inc.php"); | 
					
						
							| 
									
										
										
										
											2008-03-22 23:09:35 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | $start = utime(); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | ### Observer Device Discovery
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | echo("Observer v".$config['version']." Discovery\n\n"); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-11-07 02:30:38 +00:00
										 |  |  | $options = getopt("h:t:i:n:d::a::"); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | if ($options['h'] == "odd") { | 
					
						
							|  |  |  |   $where = "AND MOD(device_id,2) = 1";  $doing = $options['h']; | 
					
						
							|  |  |  | } elseif ($options['h'] == "even") { | 
					
						
							|  |  |  |   $where = "AND MOD(device_id,2) = 0";  $doing = $options['h']; | 
					
						
							|  |  |  | } elseif ($options['h'] == "all") { | 
					
						
							|  |  |  |   $where = " ";  $doing = "all"; | 
					
						
							|  |  |  | } elseif($options['h']) { | 
					
						
							|  |  |  |   $where = "AND `device_id` = '".$options['h']."'";  $doing = "Host ".$options['h']; | 
					
						
							|  |  |  | } elseif ($options['i'] && isset($options['n'])) { | 
					
						
							|  |  |  |   $where = "AND MOD(device_id,".$options['i'].") = '" . $options['n'] . "'";  $doing = "Proc ".$options['n'] ."/".$options['i']; | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | if(!$where) { | 
					
						
							|  |  |  |   echo("-h <device id>                Poll single device\n"); | 
					
						
							|  |  |  |   echo("-h odd                        Poll odd numbered devices  (same as -i 2 -n 0)\n"); | 
					
						
							|  |  |  |   echo("-h even                       Poll even numbered devices (same as -i 2 -n 1)\n"); | 
					
						
							|  |  |  |   echo("-h all                        Poll all devices\n\n"); | 
					
						
							|  |  |  |   echo("-i <instances> -n <number>    Poll as instance <number> of <instances>\n"); | 
					
						
							|  |  |  |   echo("                              Instances start at 0. 0-3 for -n 4\n\n"); | 
					
						
							|  |  |  |   echo("-d                            Enable some debugging output\n"); | 
					
						
							|  |  |  |   echo("\n"); | 
					
						
							| 
									
										
										
										
											2008-03-23 21:32:54 +00:00
										 |  |  |   echo("No polling type specified!\n"); | 
					
						
							|  |  |  |   exit; | 
					
						
							| 
									
										
										
										
											2009-11-07 02:30:38 +00:00
										 |  |  |  } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2010-01-16 21:53:35 +00:00
										 |  |  | if (file_exists('.svn')) | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  |   list(,$dbu_rev) = split(': ',@shell_exec('svn info database-update.sql|grep ^Revision')); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |   $device_query = mysql_query("SELECT revision FROM `dbSchema`"); | 
					
						
							|  |  |  |   if ($rev = @mysql_fetch_array($device_query))  | 
					
						
							|  |  |  |   { | 
					
						
							|  |  |  |     $db_rev = $rev['revision']; | 
					
						
							|  |  |  |   }  | 
					
						
							|  |  |  |   else  | 
					
						
							|  |  |  |   {  | 
					
						
							|  |  |  |     $db_rev = 0; | 
					
						
							|  |  |  |   } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |   if ($dbu_rev+0 > $db_rev) | 
					
						
							|  |  |  |   { | 
					
						
							|  |  |  |     echo("Applying database updates to from r$db_rev to r" . trim($dbu_rev) . "...\n"); | 
					
						
							|  |  |  |     shell_exec("scripts/update-sql.php database-update.sql"); | 
					
						
							| 
									
										
										
										
											2010-01-17 00:42:48 +00:00
										 |  |  |     if ($db_rev == 0) | 
					
						
							| 
									
										
										
										
											2010-01-16 23:56:33 +00:00
										 |  |  |     { | 
					
						
							|  |  |  |       mysql_query("INSERT INTO dbSchema VALUES ($dbu_rev)"); | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  |     else | 
					
						
							|  |  |  |     { | 
					
						
							|  |  |  |       mysql_query("UPDATE dbSchema set revision=$dbu_rev"); | 
					
						
							|  |  |  |     } | 
					
						
							| 
									
										
										
										
											2010-01-16 21:53:35 +00:00
										 |  |  |   } | 
					
						
							|  |  |  | } | 
					
						
							| 
									
										
										
										
											2009-12-02 03:36:11 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2010-01-16 23:56:33 +00:00
										 |  |  | if(isset($options['d'])) { echo("DEBUG!\n"); $debug = 1; } else { $debug = 0; } | 
					
						
							| 
									
										
										
										
											2008-03-23 21:32:54 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-04-13 19:16:22 +00:00
										 |  |  | $devices_discovered = 0; | 
					
						
							| 
									
										
										
										
											2008-03-22 23:09:35 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2008-03-31 13:08:17 +00:00
										 |  |  | $device_query = mysql_query("SELECT * FROM `devices` WHERE status = '1' $where ORDER BY device_id DESC"); | 
					
						
							| 
									
										
										
										
											2008-03-22 23:09:35 +00:00
										 |  |  | while ($device = mysql_fetch_array($device_query)) { | 
					
						
							| 
									
										
										
										
											2010-01-31 13:49:08 +00:00
										 |  |  |   $devices[] = $device; | 
					
						
							|  |  |  | } | 
					
						
							| 
									
										
										
										
											2008-03-22 23:09:35 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2010-01-31 13:49:08 +00:00
										 |  |  | foreach ($devices as $device) | 
					
						
							|  |  |  | { | 
					
						
							| 
									
										
										
										
											2009-11-28 09:48:23 +00:00
										 |  |  |   echo($device['hostname'] . " ".$device['device_id']." ".$device['os']." "); | 
					
						
							| 
									
										
										
										
											2010-01-16 23:56:33 +00:00
										 |  |  |   if($os_groups[$device['os']]) {$device['os_group'] = $os_groups[$device['os']]; echo "(".$device['os_group'].")";} | 
					
						
							| 
									
										
										
										
											2009-11-28 09:48:23 +00:00
										 |  |  |   echo("\n"); | 
					
						
							| 
									
										
										
										
											2008-03-22 23:09:35 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-12-02 23:50:09 +00:00
										 |  |  |   ## Discover OS Changes
 | 
					
						
							| 
									
										
										
										
											2010-02-13 07:40:43 +00:00
										 |  |  |   #include("includes/discovery/os.inc.php");
 | 
					
						
							| 
									
										
										
										
											2009-12-02 23:50:09 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2008-03-22 23:09:35 +00:00
										 |  |  |   ## Discover Interfaces 
 | 
					
						
							|  |  |  |   include("includes/discovery/interfaces.php"); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-11-24 23:58:56 +00:00
										 |  |  |   ## Discovery ENTITY-MIB 
 | 
					
						
							|  |  |  |   include("includes/discovery/entity-physical.inc.php"); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2008-11-03 17:09:38 +00:00
										 |  |  |   ## Discover IPv4 Addresses
 | 
					
						
							| 
									
										
										
										
											2009-04-13 19:16:22 +00:00
										 |  |  |   include("includes/discovery/ipv4-addresses.php"); | 
					
						
							| 
									
										
										
										
											2008-03-22 23:09:35 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2008-11-03 17:09:38 +00:00
										 |  |  |   ## Discovery IPv6 Addresses
 | 
					
						
							|  |  |  |   include("includes/discovery/ipv6-addresses.php"); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2010-02-09 23:19:14 +00:00
										 |  |  |   ## Discover Temperatures/Voltages/Fanspeeds
 | 
					
						
							| 
									
										
										
										
											2008-03-22 23:09:35 +00:00
										 |  |  |   include("includes/discovery/temperatures.php"); | 
					
						
							| 
									
										
										
										
											2010-02-09 23:19:14 +00:00
										 |  |  |   include("includes/discovery/voltages.php"); | 
					
						
							|  |  |  |   include("includes/discovery/fanspeeds.php"); | 
					
						
							| 
									
										
										
										
											2008-03-22 23:09:35 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-11-07 02:30:38 +00:00
										 |  |  |   ## Discover Storage
 | 
					
						
							|  |  |  |   include("includes/discovery/storage.php"); | 
					
						
							| 
									
										
										
										
											2008-04-03 19:04:24 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-11-09 15:52:04 +00:00
										 |  |  |   ## hr-device.inc.php
 | 
					
						
							|  |  |  |   include("includes/discovery/hr-device.inc.php"); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2010-01-07 16:46:55 +00:00
										 |  |  |   ## CDP & LLDP
 | 
					
						
							|  |  |  |   include("includes/discovery/cdp-lldp.inc.php"); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2010-01-13 23:40:07 +00:00
										 |  |  |   ## ARP Table
 | 
					
						
							|  |  |  |   include("includes/discovery/arp-table.php"); | 
					
						
							| 
									
										
										
										
											2010-01-07 16:46:55 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2010-02-10 15:29:19 +00:00
										 |  |  |   if($device['os'] == "screenos") {  | 
					
						
							| 
									
										
										
										
											2009-12-28 12:00:57 +00:00
										 |  |  |     if ($device['type'] == "unknown") { $device['type'] = 'firewall'; } | 
					
						
							|  |  |  |   } | 
					
						
							| 
									
										
										
										
											2008-04-03 19:04:24 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-12-27 02:37:30 +00:00
										 |  |  |   if($device['os'] == "junos") {  | 
					
						
							|  |  |  |     include("includes/discovery/bgp-peers.php");  | 
					
						
							| 
									
										
										
										
											2009-12-28 12:00:57 +00:00
										 |  |  |     if ($device['type'] == "unknown") { $device['type'] = 'network'; } # FIXME: could also be a Netscreen...
 | 
					
						
							| 
									
										
										
										
											2009-12-27 02:37:30 +00:00
										 |  |  |   } | 
					
						
							| 
									
										
										
										
											2010-01-29 17:09:47 +00:00
										 |  |  |    | 
					
						
							| 
									
										
										
										
											2010-02-05 21:03:07 +00:00
										 |  |  |   if($device['os'] == "junose") {  | 
					
						
							|  |  |  |     include("includes/discovery/bgp-peers.php");  | 
					
						
							|  |  |  |   } | 
					
						
							|  |  |  |    | 
					
						
							| 
									
										
										
										
											2010-01-31 13:49:08 +00:00
										 |  |  |   if ($device['os_group'] == "unix") | 
					
						
							| 
									
										
										
										
											2010-01-29 17:09:47 +00:00
										 |  |  |   { | 
					
						
							|  |  |  |     # Also discover quagga peers
 | 
					
						
							|  |  |  |     include("includes/discovery/bgp-peers.php"); | 
					
						
							|  |  |  |   } | 
					
						
							| 
									
										
										
										
											2009-09-03 15:13:53 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2010-01-03 22:13:50 +00:00
										 |  |  |   if($device['os'] == "ios" || $device['os'] == "iosxe" || $device['os'] == "catos" || $device['os'] == "asa" || $device['os'] == "pix") { | 
					
						
							| 
									
										
										
										
											2008-03-22 23:09:35 +00:00
										 |  |  |     include("includes/discovery/cisco-vlans.php"); | 
					
						
							|  |  |  |     include("includes/discovery/bgp-peers.php"); | 
					
						
							| 
									
										
										
										
											2009-05-06 16:50:51 +00:00
										 |  |  |     include("includes/discovery/cisco-mac-accounting.php"); | 
					
						
							| 
									
										
										
										
											2008-10-28 18:25:53 +00:00
										 |  |  |     include("includes/discovery/cisco-pw.php"); | 
					
						
							| 
									
										
										
										
											2008-10-28 22:06:00 +00:00
										 |  |  |     include("includes/discovery/cisco-vrf.php"); | 
					
						
							| 
									
										
										
										
											2009-04-11 19:10:48 +00:00
										 |  |  |     include("includes/discovery/cisco-processors.php"); | 
					
						
							| 
									
										
										
										
											2009-11-10 14:15:32 +00:00
										 |  |  |     include("includes/discovery/cemp-mib.php"); | 
					
						
							|  |  |  |     include("includes/discovery/cmp-mib.php"); | 
					
						
							| 
									
										
										
										
											2009-12-28 12:00:57 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  |     if ($device['type'] == "unknown") { $device['type'] = 'network'; }; | 
					
						
							|  |  |  |   } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2010-01-03 22:13:50 +00:00
										 |  |  |   if ($device['os'] == "procurve" || $device['os'] == "powerconnect") | 
					
						
							| 
									
										
										
										
											2009-12-28 12:00:57 +00:00
										 |  |  |   { | 
					
						
							| 
									
										
										
										
											2010-01-03 22:13:50 +00:00
										 |  |  |     include("includes/discovery/q-bridge-mib.php"); | 
					
						
							| 
									
										
										
										
											2009-12-28 12:00:57 +00:00
										 |  |  |     if ($device['type'] == "unknown") { $device['type'] = 'network'; }; | 
					
						
							|  |  |  |   } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |   if ($device['os'] == "asa" || $device['os'] == "pix") | 
					
						
							|  |  |  |   { | 
					
						
							|  |  |  |     if ($device['type'] == "unknown") { $device['type'] = 'firewall'; } | 
					
						
							| 
									
										
										
										
											2008-03-22 23:09:35 +00:00
										 |  |  |   } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2010-01-28 17:46:41 +00:00
										 |  |  |   if ($device['os'] == "dell-laser") | 
					
						
							|  |  |  |   { | 
					
						
							|  |  |  |     if ($device['type'] == "unknown") { $device['type'] = 'printer'; } | 
					
						
							|  |  |  |   } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-11-28 09:48:23 +00:00
										 |  |  |   $update_query  = "UPDATE `devices` SET "; | 
					
						
							| 
									
										
										
										
											2009-12-28 12:00:57 +00:00
										 |  |  |   $update_query .= " `last_discovered` = NOW(), `type` = '" . $device['type'] . "'"; | 
					
						
							| 
									
										
										
										
											2009-11-28 09:48:23 +00:00
										 |  |  |   $update_query .= " WHERE `device_id` = '" . $device['device_id'] . "'"; | 
					
						
							|  |  |  |   $update_result = mysql_query($update_query); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-04-13 19:16:22 +00:00
										 |  |  |   echo("\n"); $devices_discovered++; | 
					
						
							| 
									
										
										
										
											2008-03-22 23:09:35 +00:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | $end = utime(); $run = $end - $start; | 
					
						
							|  |  |  | $proctime = substr($run, 0, 5); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-04-13 19:16:22 +00:00
										 |  |  | echo("$devices_discovered devices discovered in $proctime secs\n"); | 
					
						
							| 
									
										
										
										
											2008-03-22 23:09:35 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | ?>
 |