= $nentries) break; $alert = parse_snort_alert_line($logent); if ($alert != "") { $counter++; $snortalerts[] = $alert; } } /* Since the rules are in reverse order, flip them around if needed based on the user's preference */ return isset($config['syslog']['reverse']) ? $snortalerts : array_reverse($snortalerts); } function parse_snort_alert_line($line) { $log_split = ""; $datesplit = ""; preg_match("/^(.*)\s+\[\*\*\]\s+\[(\d+\:\d+:\d+)\]\s(.*)\s(.*)\s+\[\*\*\].*\s+\[Priority:\s(\d+)\]\s{(.*)}\s+(.*)\s->\s(.*)$/U", $line, $log_split); list($all, $alert['time'], $alert['rule'], $alert['category'], $alert['descr'], $alert['priority'], $alert['proto'], $alert['src'], $alert['dst']) = $log_split; $usableline = true; if(trim($alert['src']) == "") $usableline = false; if(trim($alert['dst']) == "") $usableline = false; if($usableline == true) { preg_match("/^(\d+)\/(\d+)-(\d+\:\d+\:\d+).\d+$/U", $alert['time'], $datesplit); $now_time = strtotime("now"); $checkdate = $datesplit[1] . "/" . $datesplit[2] . "/" . date("Y"); $fulldate = $datesplit[2] . "/" . $datesplit[1] . "/" . date("Y"); $logdate = $checkdate . " " . $datesplit[3]; if ($now_time < strtotime($logdate)) { $fulldate = $datesplit[2] . "/" . $datesplit[1] . "/" . ((int)date("Y") - 1); } $alert['dateonly'] = $fulldate; $alert['timeonly'] = $datesplit[3]; $alert['category'] = strtoupper( substr($alert["category"],0 , 1) ) . strtolower( substr($alert["category"],1 ) ); return $alert; } else { if($g['debug']) { log_error("There was a error parsing line: $line. Please report to mailing list or forum."); } return ""; } } /* AJAX specific handlers */ function handle_snort_ajax($snort_alerts_logfile, $nentries = 5, $tail = 50) { if($_GET['lastsawtime'] or $_POST['lastsawtime']) { if($_GET['lastsawtime']) $lastsawtime = $_GET['lastsawtime']; if($_POST['lastsawtime']) $lastsawtime = $_POST['lastsawtime']; /* compare lastsawrule's time stamp to alert logs. * afterwards return the newer records so that client * can update AJAX interface screen. */ $new_rules = ""; $snort_alerts = get_snort_alerts($snort_alerts_logfile, $nentries); foreach($snort_alerts as $log_row) { $time_regex = ""; preg_match("/.*([0-9][0-9])\/([0-9][0-9])-([0-9][0-9]:[0-9][0-9]:[0-9][0-9]).*/", $log_row['time'], $time_regex); $logdate = $time_regex[1] . "/" . $time_regex[2] . "/" . date("Y") . " " . $time_regex[3]; //preg_match("/.*([0-9][0-9])\/([0-9][0-9])-([0-9][0-9]:[0-9][0-9]:[0-9][0-9]).*/", $testsplit[1], $time_regex); // preg_match("/.*([0-9][0-9]:[0-9][0-9]:[0-9][0-9]).*/", $log_row['time'], $time_regex); $row_time = strtotime($logdate); $now_time = strtotime("now"); if($row_time > $lastsawtime and $row_time <= $nowtime) { $new_rules .= "{$log_row['time']}||{$log_row['priority']}||{$log_row['category']}||{$log_row['src']}||{$log_row['dst']}||" . time() . "||{$log_row['timeonly']}||{$log_row['dateonly']}" . "||\n"; } } echo $new_rules; exit; } } ?>