mirror of
				https://github.com/librenms/librenms.git
				synced 2024-10-07 16:52:45 +00:00 
			
		
		
		
	
		
			
				
	
	
		
			129 lines
		
	
	
		
			4.5 KiB
		
	
	
	
		
			PHP
		
	
	
	
	
	
			
		
		
	
	
			129 lines
		
	
	
		
			4.5 KiB
		
	
	
	
		
			PHP
		
	
	
	
	
	
| <?php
 | |
| 
 | |
| if ($device['os_group'] == 'cisco') {
 | |
| // FIXME - seems to be broken. IPs appear with leading zeroes.
 | |
|     $ipsec_array = snmpwalk_cache_oid($device, 'cipSecTunnelEntry', array(), 'CISCO-IPSEC-FLOW-MONITOR-MIB');
 | |
|     $ike_array = snmpwalk_cache_oid($device, 'cikeTunnelEntry', array(), 'CISCO-IPSEC-FLOW-MONITOR-MIB');
 | |
| 
 | |
|     $tunnels_db = dbFetchRows('SELECT * FROM `ipsec_tunnels` WHERE `device_id` = ?', array($device['device_id']));
 | |
|     foreach ($tunnels_db as $tunnel) {
 | |
|         if (empty($tunnel['peer_addr']) && empty($tunnel['local_addr'])) {
 | |
|             dbDelete('ipsec_tunnels', '`tunnel_id` = ?', array($tunnel['tunnel_id']));
 | |
|         }
 | |
| 
 | |
|         $tunnels[$tunnel['peer_addr']] = $tunnel;
 | |
|     }
 | |
| 
 | |
|     $valid_tunnels = array();
 | |
| 
 | |
|     foreach ($ipsec_array as $index => $tunnel) {
 | |
|         $tunnel = array_merge($tunnel, $ike_array[$tunnel['cipSecTunIkeTunnelIndex']]);
 | |
| 
 | |
|         echo "Tunnel $index (" . $tunnel['cipSecTunIkeTunnelIndex'] . ")\n";
 | |
| 
 | |
|         echo 'Address ' . $tunnel['cikeTunRemoteValue'] . "\n";
 | |
| 
 | |
|         $address = $tunnel['cikeTunRemoteValue'];
 | |
| 
 | |
|         $oids = array(
 | |
|             'cipSecTunInOctets',
 | |
|             'cipSecTunInDecompOctets',
 | |
|             'cipSecTunInPkts',
 | |
|             'cipSecTunInDropPkts',
 | |
|             'cipSecTunInReplayDropPkts',
 | |
|             'cipSecTunInAuths',
 | |
|             'cipSecTunInAuthFails',
 | |
|             'cipSecTunInDecrypts',
 | |
|             'cipSecTunInDecryptFails',
 | |
|             'cipSecTunOutOctets',
 | |
|             'cipSecTunOutUncompOctets',
 | |
|             'cipSecTunOutPkts',
 | |
|             'cipSecTunOutDropPkts',
 | |
|             'cipSecTunOutAuths',
 | |
|             'cipSecTunOutAuthFails',
 | |
|             'cipSecTunOutEncrypts',
 | |
|             'cipSecTunOutEncryptFails',
 | |
|         );
 | |
| 
 | |
|         $db_oids = array(
 | |
|             'cipSecTunStatus' => 'tunnel_status',
 | |
|             'cikeTunLocalName' => 'tunnel_name',
 | |
|             'cikeTunLocalValue' => 'local_addr',
 | |
|         );
 | |
| 
 | |
|         if (!is_array($tunnels[$tunnel['cikeTunRemoteValue']]) && !empty($tunnel['cikeTunRemoteValue'])) {
 | |
|             $tunnel_id = dbInsert(array(
 | |
|                 'device_id' => $device['device_id'],
 | |
|                 'peer_addr' => $tunnel['cikeTunRemoteValue'],
 | |
|                 'local_addr' => $tunnel['cikeTunLocalValue'],
 | |
|                 'tunnel_name' => $tunnel['cikeTunLocalName']
 | |
|             ), 'ipsec_tunnels');
 | |
|             $valid_tunnels[] = $tunnel_id;
 | |
|         } else {
 | |
|             foreach ($db_oids as $db_oid => $db_value) {
 | |
|                 $db_update[$db_value] = $tunnel[$db_oid];
 | |
|             }
 | |
| 
 | |
|             $updated = dbUpdate(
 | |
|                 $db_update,
 | |
|                 'ipsec_tunnels',
 | |
|                 '`tunnel_id` = ?',
 | |
|                 array($tunnels[$tunnel['cikeTunRemoteValue']]['tunnel_id'])
 | |
|             );
 | |
|             $valid_tunnels[] = $tunnels[$tunnel['cikeTunRemoteValue']]['tunnel_id'];
 | |
|         }
 | |
| 
 | |
|         if (is_numeric($tunnel['cipSecTunHcInOctets']) &&
 | |
|             is_numeric($tunnel['cipSecTunHcInDecompOctets']) &&
 | |
|             is_numeric($tunnel['cipSecTunHcOutOctets']) &&
 | |
|             is_numeric($tunnel['cipSecTunHcOutUncompOctets'])
 | |
|         ) {
 | |
|             echo 'HC ';
 | |
| 
 | |
|             $tunnel['cipSecTunInOctets'] = $tunnel['cipSecTunHcInOctets'];
 | |
|             $tunnel['cipSecTunInDecompOctets'] = $tunnel['cipSecTunHcInDecompOctets'];
 | |
|             $tunnel['cipSecTunOutOctets'] = $tunnel['cipSecTunHcOutOctets'];
 | |
|             $tunnel['cipSecTunOutUncompOctets'] = $tunnel['cipSecTunHcOutUncompOctets'];
 | |
|         }
 | |
| 
 | |
|         $rrd_name = array('ipsectunnel', $address);
 | |
|         $rrd_def = array();
 | |
|         foreach ($oids as $oid) {
 | |
|             $oid_ds = truncate(str_replace('cipSec', '', $oid), 19, '');
 | |
|             $rrd_def[] = "DS:$oid_ds:COUNTER:600:U:1000000000";
 | |
|         }
 | |
| 
 | |
|         $fields = array();
 | |
| 
 | |
|         foreach ($oids as $oid) {
 | |
|             if (is_numeric($tunnel[$oid])) {
 | |
|                 $value = $tunnel[$oid];
 | |
|             } else {
 | |
|                 $value = '0';
 | |
|             }
 | |
|             $fields[$oid] = $value;
 | |
|         }
 | |
| 
 | |
|         if (isset($tunnel['cikeTunRemoteValue'])) {
 | |
|             $tags = compact('address', 'rrd_name', 'rrd_def');
 | |
|             data_update($device, 'ipsectunnel', $tags, $fields);
 | |
| 
 | |
|             // $graphs['ipsec_tunnels'] = TRUE;
 | |
|         }
 | |
|     }//end foreach
 | |
| 
 | |
|     if (is_array($valid_tunnels)) {
 | |
|         d_echo($valid_tunnels);
 | |
|         if (empty($valid_tunnels)) {
 | |
|             $valid_tunnels = array(0);
 | |
|         }
 | |
|         dbDelete(
 | |
|             'ipsec_tunnels',
 | |
|             "`tunnel_id` NOT IN (" . implode(',', $valid_tunnels) . ") AND `device_id`=?",
 | |
|             array($device['device_id'])
 | |
|         );
 | |
|     }
 | |
| 
 | |
|     unset($rrd_name, $rrd_def, $fields, $oids, $data, $data, $oid, $tunnel);
 | |
| }
 |