user/dev discussion of public-inbox itself
 help / color / mirror / code / Atom feed
From: Eric Wong <e@80x24.org>
To: meta@public-inbox.org
Subject: [PATCH 2/7] nntp: support YYYYMMDD dates for commands
Date: Tue, 22 Sep 2015 10:09:43 +0000	[thread overview]
Message-ID: <20150922100948.8160-3-e@80x24.org> (raw)
In-Reply-To: <20150922100948.8160-1-e@80x24.org>

RFC 3977 supports YYYYMMDD dates while retaining backwards
compatibility for old YYMMDD dates.
---
 lib/PublicInbox/NNTP.pm | 18 +++++++++++-------
 t/nntp.t                | 29 +++++++++++++++++++++++++++++
 2 files changed, 40 insertions(+), 7 deletions(-)

diff --git a/lib/PublicInbox/NNTP.pm b/lib/PublicInbox/NNTP.pm
index 91b10f2..bc8d6ed 100644
--- a/lib/PublicInbox/NNTP.pm
+++ b/lib/PublicInbox/NNTP.pm
@@ -169,22 +169,26 @@ sub cmd_listgroup ($;$) {
 sub parse_time ($$;$) {
 	my ($date, $time, $gmt) = @_;
 	use Time::Local qw();
-	my ($YY, $MM, $DD) = unpack('A2A2A2', $date);
 	my ($hh, $mm, $ss) = unpack('A2A2A2', $time);
 	if (defined $gmt) {
 		$gmt =~ /\A(?:UTC|GMT)\z/i or die "GM invalid: $gmt\n";
 		$gmt = 1;
 	}
 	my @now = $gmt ? gmtime : localtime;
-	if ($YY > strftime('%y', @now)) {
-		my $cur_year = $now[5] + 1900;
-		$YY += int($cur_year / 1000) * 1000 - 100;
+	my ($YYYY, $MM, $DD);
+	if (length($date) == 8) { # RFC 3977 allows YYYYMMDD
+		($YYYY, $MM, $DD) = unpack('A4A2A2', $date);
+	} else { # legacy clients send YYMMDD
+		($YYYY, $MM, $DD) = unpack('A2A2A2', $date);
+		if ($YYYY > strftime('%y', @now)) {
+			my $cur_year = $now[5] + 1900;
+			$YYYY += int($cur_year / 1000) * 1000 - 100;
+		}
 	}
-
 	if ($gmt) {
-		Time::Local::timegm($ss, $mm, $hh, $DD, $MM - 1, $YY);
+		Time::Local::timegm($ss, $mm, $hh, $DD, $MM - 1, $YYYY);
 	} else {
-		Time::Local::timelocal($ss, $mm, $hh, $DD, $MM - 1, $YY);
+		Time::Local::timelocal($ss, $mm, $hh, $DD, $MM - 1, $YYYY);
 	}
 }
 
diff --git a/t/nntp.t b/t/nntp.t
index 82918ff..c917888 100644
--- a/t/nntp.t
+++ b/t/nntp.t
@@ -61,4 +61,33 @@ use_ok 'PublicInbox::NNTP';
 	ngpat_like('a.s.r', 'a.t,a.s.*');
 }
 
+{
+	use POSIX qw(strftime);
+	sub time_roundtrip {
+		my ($date, $time, $gmt) = @_;
+		my $m = join(' ', @_);
+		my $ts = PublicInbox::NNTP::parse_time(@_);
+		my @t = gmtime($ts);
+		my ($d, $t);
+		if (length($date) == 8) {
+			($d, $t) = split(' ', strftime('%Y%m%d %H%M%S', @t));
+		} else {
+			($d, $t) = split(' ', strftime('%g%m%d %H%M%S', @t));
+		}
+		is_deeply([$d, $t], [$date, $time], "roundtripped: $m");
+		$ts;
+	}
+	my $x1 = time_roundtrip(qw(20141109 060606 GMT));
+	my $x2 = time_roundtrip(qw(141109 060606 GMT));
+	my $x3 = time_roundtrip(qw(930724 060606 GMT));
+
+	SKIP: {
+		skip('YYMMDD test needs updating', 2) if (time > 0x7fffffff);
+		# our world probably ends in 2038, but if not we'll try to
+		# remember to update the test then
+		is($x1, $x2, 'YYYYMMDD and YYMMDD parse identically');
+		is(strftime('%Y', gmtime($x3)), '1993', '930724 was in 1993');
+	}
+}
+
 done_testing();
-- 
EW


  parent reply	other threads:[~2015-09-22 10:09 UTC|newest]

Thread overview: 8+ messages / expand[flat|nested]  mbox.gz  Atom feed  top
2015-09-22 10:09 [PATCH 0/7] nntp: another round of updates Eric Wong
2015-09-22 10:09 ` [PATCH 1/7] t/nntpd.t: fix fcntl test to ensure no failures Eric Wong
2015-09-22 10:09 ` Eric Wong [this message]
2015-09-22 10:09 ` [PATCH 3/7] nntp: ensure body lines end with CRLF Eric Wong
2015-09-22 10:09 ` [PATCH 4/7] nntp: avoid setting Bytes and Lines headers Eric Wong
2015-09-22 10:09 ` [PATCH 5/7] nntp: implement OVER from RFC 3977 Eric Wong
2015-09-22 10:09 ` [PATCH 6/7] nntp: XHDR fixes for Message-ID lookups Eric Wong
2015-09-22 10:09 ` [PATCH 7/7] nntp: XHDR lookups by Message-ID may cross groups Eric Wong

Reply instructions:

You may reply publicly to this message via plain-text email
using any one of the following methods:

* Save the following mbox file, import it into your mail client,
  and reply-to-all from there: mbox

  Avoid top-posting and favor interleaved quoting:
  https://en.wikipedia.org/wiki/Posting_style#Interleaved_style

  List information: https://public-inbox.org/README

* Reply using the --to, --cc, and --in-reply-to
  switches of git-send-email(1):

  git send-email \
    --in-reply-to=20150922100948.8160-3-e@80x24.org \
    --to=e@80x24.org \
    --cc=meta@public-inbox.org \
    /path/to/YOUR_REPLY

  https://kernel.org/pub/software/scm/git/docs/git-send-email.html

* If your mail client supports setting the In-Reply-To header
  via mailto: links, try the mailto: link
Be sure your reply has a Subject: header at the top and a blank line before the message body.
Code repositories for project(s) associated with this public inbox

	https://80x24.org/public-inbox.git

This is a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox;
as well as URLs for read-only IMAP folder(s) and NNTP newsgroup(s).