Change options behavior.

Parse RFC3164 timestamps as UTC.
This commit is contained in:
Mark Nellemann 2020-09-23 07:01:55 +02:00
parent 57eea00c2b
commit 8d832e93f2
3 changed files with 9 additions and 14 deletions

View file

@ -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);
} }

View file

@ -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);

View file

@ -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"() {