" . $port['ifDescr'] . " "); if($array[$device[device_id]][$port[ifIndex]]) { // Check to make sure Port data is cached. $this_port = &$array[$device[device_id]][$port[ifIndex]]; $polled_period = $polled - $port['poll_time']; $update .= "`poll_time` = '".$polled."'"; $update .= ", `poll_prev` = '".$port['poll_time']."'"; $update .= ", `poll_period` = '".$polled_period."'"; /// Copy ifHC[In|Out]Octets values to non-HC if they exist if($this_port['ifHCInOctets'] > 0 && is_numeric($this_port['ifHCInOctets']) && $this_port['ifHCOutOctets'] > 0 && is_numeric($this_port['ifHCOutOctets'])) { echo("HC "); $this_port['ifInOctets'] = $this_port['ifHCInOctets']; $this_port['ifOutOctets'] = $this_port['ifHCOutOctets']; } /// Update IF-MIB data foreach ($data_oids as $oid) { if ( $port[$oid] != $this_port[$oid] && !isset($this_port[$oid])) { $update .= ", `$oid` = NULL"; eventlog($oid . ": ".$port[$oid]." -> NULL", $device['device_id'], $port['interface_id']); if($debug) { echo($oid . ": ".$port[$oid]." -> NULL "); } else { echo($oid . " "); } } elseif ( $port[$oid] != $this_port[$oid] ) { $update .= ", `$oid` = '".mysql_real_escape_string($this_port[$oid])."'"; eventlog($oid . ": ".$port[$oid]." -> " . $this_port[$oid], $device['device_id'], $port['interface_id']); if($debug) { echo($oid . ": ".$port[$oid]." -> " . $this_port[$oid]." "); } else { echo($oid . " "); } } } /// Update IF-MIB metrics foreach ($stat_oids_db as $oid) { $update .= ", `$oid` = '".$this_port[$oid]."'"; $update .= ", `".$oid."_prev` = '".$port[$oid]."'"; $oid_prev = $oid . "_prev"; if($port[$oid]) { $oid_diff = $this_port[$oid] - $port[$oid]; $oid_rate = $oid_diff / $polled_period; $update .= ", `".$oid."_rate` = '".$oid_rate."'"; $update .= ", `".$oid."_delta` = '".$oid_diff."'"; #echo("\n $oid ($oid_diff B) $oid_rate Bps $polled_period secs\n"); } } /// Update RRDs $rrdfile = $host_rrd . "/" . safename($port['ifIndex'] . ".rrd"); if(!is_file($rrdfile)) { $woo = shell_exec($config['rrdtool'] . " create $rrdfile -s 300 \ DS:INOCTETS:DERIVE:600:0:12500000000 \ DS:OUTOCTETS:DERIVE:600:0:12500000000 \ DS:INERRORS:DERIVE:600:0:12500000000 \ DS:OUTERRORS:DERIVE:600:0:12500000000 \ DS:INUCASTPKTS:DERIVE:600:0:12500000000 \ DS:OUTUCASTPKTS:DERIVE:600:0:12500000000 \ DS:INNUCASTPKTS:DERIVE:600:0:12500000000 \ DS:OUTNUCASTPKTS:DERIVE:600:0:12500000000 \ RRA:AVERAGE:0.5:1:600 \ RRA:AVERAGE:0.5:6:700 \ RRA:AVERAGE:0.5:24:775 \ RRA:AVERAGE:0.5:288:797 \ RRA:MAX:0.5:1:600 \ RRA:MAX:0.5:6:700 \ RRA:MAX:0.5:24:775 \ RRA:MAX:0.5:288:797"); } foreach ($stat_oids as $oid) { /// Copy values from array to global variables and force numeric. $$oid = $this_port[$oid]; if(!is_numeric($$oid)) { $$oid = "0"; } } $woo = "$polled:$ifInOctets:$ifOutOctets:$ifInErrors:$ifOutErrors:$ifInUcastPkts:$ifOutUcastPkts:$ifInNUcastPkts:$ifOutNUcastPkts"; $ret = rrdtool_update("$rrdfile", $woo); /// End Update IF-MIB /// Update PAgP if($this_port['pagpOperationMode']) { foreach ($pagp_oids as $oid) { // Loop the OIDs if ( $this_port[$oid] != $port[$oid] ) { // If data has changed, build a query $update .= ", `$oid` = '".mres($this_port[$oid])."'"; echo("PAgP "); eventlog("$oid -> ".$this_port[$oid], $device['device_id'], $port['interface_id']); } } } // End Update PAgP /// Do EtherLike-MIB if($config['enable_ports_etherlike']) { include("port-etherlike.inc.php"); } // Update MySQL if ($update) { $update_query = "UPDATE `interfaces` SET ".$update." WHERE `interface_id` = '" . $port['interface_id'] . "'"; @mysql_query($update_query); $mysql++; if($debug) {echo("\nMYSQL : [ $update_query ]");} } // End Update MySQL unset($update_query); unset($update); } else { echo("Port Deleted?"); // Port missing from SNMP cache? } echo("\n"); } ?>