Change options behavior.
Parse RFC3164 timestamps as UTC.
This commit is contained in:
parent
57eea00c2b
commit
8d832e93f2
|
@ -42,7 +42,7 @@ public class SyslogParser {
|
||||||
Matcher matcher = pattern.matcher(input);
|
Matcher matcher = pattern.matcher(input);
|
||||||
boolean matchFound = matcher.find();
|
boolean matchFound = matcher.find();
|
||||||
if(!matchFound) {
|
if(!matchFound) {
|
||||||
log.warn("Match not found");
|
log.warn("parseRfc3164() - Match not found in: " + input);
|
||||||
return null;
|
return null;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -81,7 +81,7 @@ public class SyslogParser {
|
||||||
Matcher matcher = pattern.matcher(input);
|
Matcher matcher = pattern.matcher(input);
|
||||||
boolean matchFound = matcher.find();
|
boolean matchFound = matcher.find();
|
||||||
if(!matchFound) {
|
if(!matchFound) {
|
||||||
log.warn("Match not found");
|
log.warn("parseRfc5424() - Match not found in: " + input);
|
||||||
return null;
|
return null;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -132,7 +132,7 @@ public class SyslogParser {
|
||||||
static protected Instant parseRfc3164Timestamp(String dateString) {
|
static protected Instant parseRfc3164Timestamp(String dateString) {
|
||||||
|
|
||||||
// We need to add year to parse date correctly
|
// We need to add year to parse date correctly
|
||||||
LocalDateTime dt = LocalDateTime.now();
|
OffsetDateTime odt = OffsetDateTime.now();
|
||||||
|
|
||||||
// Date: Mmm dd hh:mm:ss
|
// Date: Mmm dd hh:mm:ss
|
||||||
Instant instant = null;
|
Instant instant = null;
|
||||||
|
@ -140,8 +140,7 @@ public class SyslogParser {
|
||||||
DateTimeFormatter dateTimeFormatter = DateTimeFormatter.ofPattern("yyyy MMM dd HH:mm:ss")
|
DateTimeFormatter dateTimeFormatter = DateTimeFormatter.ofPattern("yyyy MMM dd HH:mm:ss")
|
||||||
.withLocale(Locale.getDefault())
|
.withLocale(Locale.getDefault())
|
||||||
.withZone(ZoneId.systemDefault());
|
.withZone(ZoneId.systemDefault());
|
||||||
LocalDateTime dateTime = LocalDateTime.parse(dt.getYear() + " " + dateString, dateTimeFormatter);
|
instant = Instant.from(dateTimeFormatter.parse(odt.getYear() + " " + dateString));
|
||||||
instant = dateTime.toInstant(ZoneOffset.UTC);
|
|
||||||
} catch(DateTimeParseException e) {
|
} catch(DateTimeParseException e) {
|
||||||
log.error("parseDate()", e);
|
log.error("parseDate()", e);
|
||||||
}
|
}
|
||||||
|
|
|
@ -36,13 +36,9 @@ public class SyslogServer implements Callable<Integer>, LogListener {
|
||||||
@CommandLine.Option(names = "--no-tcp", negatable = true, description = "Listen on TCP, true by default.")
|
@CommandLine.Option(names = "--no-tcp", negatable = true, description = "Listen on TCP, true by default.")
|
||||||
boolean tcpServer = true;
|
boolean tcpServer = true;
|
||||||
|
|
||||||
@CommandLine.Option(names = "--rfc3164", negatable = true, description = "Parse RFC3164 syslog message, false by default.")
|
@CommandLine.Option(names = "--rfc3164", negatable = false, description = "Parse RFC3164 syslog message, RFC5424 by default.")
|
||||||
boolean rfc3164 = false;
|
boolean rfc3164 = false;
|
||||||
|
|
||||||
@CommandLine.Option(names = "--no-rfc5424", negatable = true, description = "Parse RFC5424 syslog message, true by default.")
|
|
||||||
boolean rfc5424 = true;
|
|
||||||
|
|
||||||
|
|
||||||
public static void main(String... args) {
|
public static void main(String... args) {
|
||||||
int exitCode = new CommandLine(new SyslogServer()).execute(args);
|
int exitCode = new CommandLine(new SyslogServer()).execute(args);
|
||||||
System.exit(exitCode);
|
System.exit(exitCode);
|
||||||
|
@ -74,10 +70,10 @@ public class SyslogServer implements Callable<Integer>, LogListener {
|
||||||
String message = event.getMessage();
|
String message = event.getMessage();
|
||||||
SyslogMessage msg = null;
|
SyslogMessage msg = null;
|
||||||
try {
|
try {
|
||||||
if(rfc5424) {
|
if(rfc3164) {
|
||||||
msg = SyslogParser.parseRfc5424(message);
|
|
||||||
} else if(rfc3164) {
|
|
||||||
msg = SyslogParser.parseRfc3164(message);
|
msg = SyslogParser.parseRfc3164(message);
|
||||||
|
} else {
|
||||||
|
msg = SyslogParser.parseRfc5424(message);
|
||||||
}
|
}
|
||||||
} catch(Exception e) {
|
} catch(Exception e) {
|
||||||
log.error("Problem parsing message: ", e);
|
log.error("Problem parsing message: ", e);
|
||||||
|
|
|
@ -16,7 +16,7 @@ class SyslogParserTest extends Specification {
|
||||||
Instant inst = SyslogParser.parseRfc3164Timestamp(dateString)
|
Instant inst = SyslogParser.parseRfc3164Timestamp(dateString)
|
||||||
|
|
||||||
then:
|
then:
|
||||||
inst.toString() == "${dt.getYear()}-09-12T22:50:13Z"
|
inst.toString() == "${dt.getYear()}-09-12T20:50:13Z"
|
||||||
}
|
}
|
||||||
|
|
||||||
void "test parseRfc5424Timestamp"() {
|
void "test parseRfc5424Timestamp"() {
|
||||||
|
|
Loading…
Reference in a new issue