| 
									
										
										
										
											2008-03-22 23:09:35 +00:00
										 |  |  | #!/usr/bin/php
 | 
					
						
							|  |  |  | <?php | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2010-02-27 14:44:38 +00:00
										 |  |  | include("includes/defaults.inc.php"); | 
					
						
							| 
									
										
										
										
											2008-03-22 23:09:35 +00:00
										 |  |  | include("config.php"); | 
					
						
							|  |  |  | include("includes/functions.php"); | 
					
						
							| 
									
										
										
										
											2010-02-15 01:53:00 +00:00
										 |  |  | include("includes/discovery/functions.inc.php"); | 
					
						
							| 
									
										
										
										
											2008-03-22 23:09:35 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | $start = utime(); | 
					
						
							| 
									
										
										
										
											2010-06-19 16:06:57 +00:00
										 |  |  | $runtime_stats = array(); | 
					
						
							| 
									
										
										
										
											2008-03-22 23:09:35 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | ### 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']) { | 
					
						
							| 
									
										
										
										
											2010-06-18 18:12:35 +00:00
										 |  |  |   if (is_numeric($options['h'])) | 
					
						
							|  |  |  |   { | 
					
						
							|  |  |  |     $where = "AND `device_id` = '".$options['h']."'";  $doing = "Host ".$options['h']; | 
					
						
							|  |  |  |   } | 
					
						
							|  |  |  |   else | 
					
						
							|  |  |  |   { | 
					
						
							|  |  |  |     $where = "AND `hostname` LIKE '".str_replace('*','%',mres($options['h']))."'";  $doing = "Host ".$options['h']; | 
					
						
							|  |  |  |   } | 
					
						
							| 
									
										
										
										
											2009-11-07 02:30:38 +00:00
										 |  |  | } 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')) | 
					
						
							|  |  |  | { | 
					
						
							| 
									
										
										
										
											2010-06-12 15:18:12 +00:00
										 |  |  |   list(,$dbu_rev) = preg_split('/: /',@shell_exec('svn info database-update.sql|grep ^Revision')); | 
					
						
							| 
									
										
										
										
											2010-01-16 21:53:35 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  |   $device_query = mysql_query("SELECT revision FROM `dbSchema`"); | 
					
						
							|  |  |  |   if ($rev = @mysql_fetch_array($device_query))  | 
					
						
							|  |  |  |   { | 
					
						
							|  |  |  |     $db_rev = $rev['revision']; | 
					
						
							|  |  |  |   }  | 
					
						
							|  |  |  |   else  | 
					
						
							|  |  |  |   {  | 
					
						
							|  |  |  |     $db_rev = 0; | 
					
						
							|  |  |  |   } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2010-06-20 21:37:05 +00:00
										 |  |  |   if ($dbu_rev+0 < "1223") { | 
					
						
							|  |  |  |     include("fix-events.php"); ## Fix events table (needs to copy some data around, so needs script)
 | 
					
						
							|  |  |  |   } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2010-01-16 21:53:35 +00:00
										 |  |  |   if ($dbu_rev+0 > $db_rev) | 
					
						
							|  |  |  |   { | 
					
						
							| 
									
										
										
										
											2010-03-11 18:18:39 +00:00
										 |  |  |     if($db_rev+0 < "1000") { | 
					
						
							| 
									
										
										
										
											2010-03-12 18:43:06 +00:00
										 |  |  |       echo("SVN revision changed.\nRunning pre-revision 1000 SQL update script...\n"); | 
					
						
							| 
									
										
										
										
											2010-03-10 14:56:19 +00:00
										 |  |  |       shell_exec("scripts/update-sql.php database-update-pre1000.sql"); | 
					
						
							|  |  |  |     } | 
					
						
							| 
									
										
										
										
											2010-02-28 22:04:15 +00:00
										 |  |  |     echo("SVN revision changed.\nRunning development SQL update script from r$db_rev to r" . trim($dbu_rev) . "...\n"); | 
					
						
							| 
									
										
										
										
											2010-01-16 21:53:35 +00:00
										 |  |  |     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
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2010-03-11 17:46:42 +00:00
										 |  |  | $device_query = mysql_query("SELECT * FROM `devices` WHERE status = 1 AND disabled = 0 $where ORDER BY device_id DESC"); | 
					
						
							| 
									
										
										
										
											2010-02-19 23:57:50 +00:00
										 |  |  | while ($device = mysql_fetch_array($device_query)) | 
					
						
							| 
									
										
										
										
											2010-01-31 13:49:08 +00:00
										 |  |  | { | 
					
						
							| 
									
										
										
										
											2009-11-28 09:48:23 +00:00
										 |  |  |   echo($device['hostname'] . " ".$device['device_id']." ".$device['os']." "); | 
					
						
							| 
									
										
										
										
											2010-02-16 00:38:05 +00:00
										 |  |  |   if($device['os'] != strtolower($device['os'])) { | 
					
						
							|  |  |  |     mysql_query("UPDATE `devices` SET `os` = '".strtolower($device['os'])."' WHERE device_id = '".$device['device_id']."'"); | 
					
						
							|  |  |  |     $device['os'] = strtolower($device['os']); echo("OS lowercased."); | 
					
						
							|  |  |  |   } | 
					
						
							| 
									
										
										
										
											2010-01-16 23:56:33 +00:00
										 |  |  |   if($os_groups[$device['os']]) {$device['os_group'] = $os_groups[$device['os']]; echo "(".$device['os_group'].")";} | 
					
						
							| 
									
										
										
										
											2010-02-16 00:38:05 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-11-28 09:48:23 +00:00
										 |  |  |   echo("\n"); | 
					
						
							| 
									
										
										
										
											2008-03-22 23:09:35 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2010-02-13 07:40:43 +00:00
										 |  |  |   #include("includes/discovery/os.inc.php");
 | 
					
						
							| 
									
										
										
										
											2009-12-02 23:50:09 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2010-02-20 17:29:47 +00:00
										 |  |  |   include("includes/discovery/ports.inc.php"); | 
					
						
							| 
									
										
										
										
											2010-03-11 02:53:17 +00:00
										 |  |  |   include("includes/discovery/entity-physical.inc.php"); | 
					
						
							| 
									
										
										
										
											2010-02-13 21:45:39 +00:00
										 |  |  |   include("includes/discovery/processors.inc.php"); | 
					
						
							| 
									
										
										
										
											2010-02-22 00:57:13 +00:00
										 |  |  |   include("includes/discovery/mempools.inc.php"); | 
					
						
							| 
									
										
										
										
											2010-02-20 17:29:47 +00:00
										 |  |  |   include("includes/discovery/ipv4-addresses.inc.php"); | 
					
						
							|  |  |  |   include("includes/discovery/ipv6-addresses.inc.php"); | 
					
						
							|  |  |  |   include("includes/discovery/temperatures.inc.php"); | 
					
						
							|  |  |  |   include("includes/discovery/voltages.inc.php"); | 
					
						
							| 
									
										
										
										
											2010-06-03 10:23:11 +00:00
										 |  |  |   include("includes/discovery/frequencies.inc.php"); | 
					
						
							| 
									
										
										
										
											2010-06-09 20:03:16 +00:00
										 |  |  |   include("includes/discovery/current.inc.php"); | 
					
						
							| 
									
										
										
										
											2010-02-20 17:29:47 +00:00
										 |  |  |   include("includes/discovery/fanspeeds.inc.php"); | 
					
						
							|  |  |  |   include("includes/discovery/storage.inc.php"); | 
					
						
							| 
									
										
										
										
											2009-11-09 15:52:04 +00:00
										 |  |  |   include("includes/discovery/hr-device.inc.php"); | 
					
						
							| 
									
										
										
										
											2010-02-20 15:09:31 +00:00
										 |  |  |   include("includes/discovery/discovery-protocols.inc.php"); | 
					
						
							| 
									
										
										
										
											2010-02-20 17:29:47 +00:00
										 |  |  |   include("includes/discovery/arp-table.inc.php"); | 
					
						
							| 
									
										
										
										
											2010-03-01 01:51:19 +00:00
										 |  |  |   include("includes/discovery/junose-atm-vp.inc.php"); | 
					
						
							| 
									
										
										
										
											2010-02-28 20:39:02 +00:00
										 |  |  |   include("includes/discovery/bgp-peers.inc.php"); | 
					
						
							| 
									
										
										
										
											2010-02-28 22:04:15 +00:00
										 |  |  |   include("includes/discovery/q-bridge-mib.inc.php"); | 
					
						
							|  |  |  |   include("includes/discovery/cisco-vlans.inc.php"); | 
					
						
							|  |  |  |   include("includes/discovery/cisco-mac-accounting.inc.php"); | 
					
						
							|  |  |  |   include("includes/discovery/cisco-pw.inc.php"); | 
					
						
							|  |  |  |   include("includes/discovery/cisco-vrf.inc.php"); | 
					
						
							| 
									
										
										
										
											2010-03-11 19:09:19 +00:00
										 |  |  |   include("includes/discovery/toner.inc.php"); | 
					
						
							| 
									
										
										
										
											2010-06-03 09:12:07 +00:00
										 |  |  |   include("includes/discovery/ups.inc.php"); | 
					
						
							| 
									
										
										
										
											2010-06-19 16:06:57 +00:00
										 |  |  |   include("includes/discovery/ucd-diskio.inc.php"); | 
					
						
							| 
									
										
										
										
											2010-02-28 20:39:02 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2010-06-10 20:13:41 +00:00
										 |  |  |   if ($device['type'] == "unknown") | 
					
						
							| 
									
										
										
										
											2010-01-28 17:46:41 +00:00
										 |  |  |   { | 
					
						
							| 
									
										
										
										
											2010-06-10 20:13:41 +00:00
										 |  |  |     switch ($device['os']) | 
					
						
							|  |  |  |     { | 
					
						
							|  |  |  |       case "procurve": | 
					
						
							|  |  |  |       case "powerconnect": | 
					
						
							|  |  |  |       case "ironware": | 
					
						
							|  |  |  |       case "allied": | 
					
						
							|  |  |  |       case "junos": # Could also be a Netscreen?
 | 
					
						
							|  |  |  |       case "ios": | 
					
						
							|  |  |  |       case "iosxe": | 
					
						
							|  |  |  |       case "catos": | 
					
						
							| 
									
										
										
										
											2010-06-18 15:21:40 +00:00
										 |  |  |       case "3com": | 
					
						
							| 
									
										
										
										
											2010-06-10 20:13:41 +00:00
										 |  |  |         $device['type'] = 'network';  | 
					
						
							|  |  |  |         break; | 
					
						
							|  |  |  |       case "asa": | 
					
						
							|  |  |  |       case "pix": | 
					
						
							|  |  |  |       case "screenos": | 
					
						
							|  |  |  |         $device['type'] = 'firewall';  | 
					
						
							|  |  |  |         break; | 
					
						
							|  |  |  |       case "dell-laser": | 
					
						
							|  |  |  |         $device['type'] = 'printer';  | 
					
						
							|  |  |  |         break; | 
					
						
							|  |  |  |       case "linux": | 
					
						
							| 
									
										
										
										
											2010-06-10 22:24:36 +00:00
										 |  |  |         if (preg_match("/-server$/", $device['version'])) { $device['type'] = 'server'; } | 
					
						
							| 
									
										
										
										
											2010-06-10 20:13:41 +00:00
										 |  |  |         break; | 
					
						
							|  |  |  |       case "apc": | 
					
						
							|  |  |  |       case "mgeups": | 
					
						
							| 
									
										
										
										
											2010-06-16 12:46:52 +00:00
										 |  |  |       case "netmanplus": | 
					
						
							| 
									
										
										
										
											2010-06-10 20:13:41 +00:00
										 |  |  |         $device['type'] = 'power';  | 
					
						
							|  |  |  |         break; | 
					
						
							|  |  |  |     } | 
					
						
							| 
									
										
										
										
											2010-06-10 22:25:04 +00:00
										 |  |  |   } | 
					
						
							| 
									
										
										
										
											2010-02-28 22:04:15 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											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
										 |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | ?>
 |