mirror of
				https://github.com/librenms/librenms.git
				synced 2024-10-07 16:52:45 +00:00 
			
		
		
		
	
		
			
				
	
	
		
			60 lines
		
	
	
		
			2.3 KiB
		
	
	
	
		
			PHP
		
	
	
		
			Executable File
		
	
	
	
	
			
		
		
	
	
			60 lines
		
	
	
		
			2.3 KiB
		
	
	
	
		
			PHP
		
	
	
		
			Executable File
		
	
	
	
	
| <?php
 | |
| 
 | |
| echo("hrDevice : ");
 | |
| 
 | |
| $hrDevice_oids = array('hrDeviceEntry','hrProcessorEntry');
 | |
| if ($debug) { print_r($hrDevices); }
 | |
| 
 | |
| $hrDevices = array();
 | |
| foreach ($hrDevice_oids as $oid) { $hrDevices = snmpwalk_cache_oid($device, $oid, $hrDevices, "HOST-RESOURCES-MIB:HOST-RESOURCES-TYPES"); }
 | |
| if ($debug) { print_r($hrDevices); }
 | |
| 
 | |
| if (is_array($hrDevices))
 | |
| {
 | |
|   $hrDevices = $hrDevices;
 | |
|   foreach ($hrDevices as $hrDevice)
 | |
|   {
 | |
|     if (is_array($hrDevice) && is_numeric($hrDevice['hrDeviceIndex']))
 | |
|     {
 | |
|       if (dbFetchCell("SELECT COUNT(*) FROM `hrDevice` WHERE device_id = ? AND hrDeviceIndex = ?",array($device['device_id'], $hrDevice['hrDeviceIndex'])))
 | |
|       {
 | |
|         $update_array = array('hrDeviceType' => mres($hrDevice['hrDeviceType']),
 | |
|         'hrDeviceDescr' => mres($hrDevice['hrDeviceDescr']),
 | |
|         'hrDeviceStatus' => mres($hrDevice['hrDeviceStatus']),
 | |
|         'hrDeviceErrors' => mres($hrDevice['hrDeviceErrors']));
 | |
|         if ($hrDevice['hrDeviceType'] == "hrDeviceProcessor")
 | |
|         {
 | |
|           $update_array['hrProcessorLoad'] = mres($hrDevice['hrProcessorLoad']);
 | |
|         }
 | |
|         dbUpdate($update_array, 'hrDevice', 'device_id=? AND hrDeviceIndex=?',array($device['device_id'],$hrDevice['hrDeviceIndex']));
 | |
|         echo(".");
 | |
|       }
 | |
|       else
 | |
|       {
 | |
|         $inserted_rows = dbInsert(array('hrDeviceIndex' => mres($hrDevice['hrDeviceIndex']), 'device_id' => mres($device['device_id']), 'hrDeviceType' => mres($hrDevice['hrDeviceType']),'hrDeviceDescr' => mres($hrDevice['hrDeviceDescr']), 'hrDeviceStatus' => mres($hrDevice['hrDeviceStatus']), 'hrDeviceErrors' => mres($hrDevice['hrDeviceErrors'])), 'hrDevice');
 | |
|         echo("+");
 | |
|         if ($debug) { print_r($hrDevice); echo("$inserted_rows row inserted"); }
 | |
|       }
 | |
|       $valid_hrDevice[$hrDevice['hrDeviceIndex']] = 1;
 | |
|     }
 | |
|   }
 | |
| }
 | |
| 
 | |
| $sql = "SELECT * FROM `hrDevice` WHERE `device_id`  = '".$device['device_id']."'";
 | |
| 
 | |
| foreach (dbFetchRows($sql) as $test_hrDevice)
 | |
| {
 | |
|   if (!$valid_hrDevice[$test_hrDevice['hrDeviceIndex']])
 | |
|   {
 | |
|     echo("-");
 | |
|     mysql_query("DELETE FROM `hrDevice` WHERE hrDevice_id = '" . $test_hrDevice['hrDevice_id'] . "'");
 | |
|     dbDelete('hrDevice', '`hrDevice_id` = ?', array($test_hrDevice['hrDevice_id']));
 | |
|     if ($debug) { print_r($test_hrDevice); echo(mysql_affected_rows() . " row deleted"); }
 | |
|   }
 | |
| }
 | |
| 
 | |
| unset($valid_hrDevice);
 | |
| echo("\n");
 | |
| 
 | |
| ?>
 |