git($self)->check('HEAD:'.$path);
}
+sub mid2num($$) {
+ my ($self, $mid) = @_;
+ my $mm = mm($self) or return;
+ $mm->num_for($mid);
+}
+
sub smsg_by_mid ($$) {
my ($self, $mid) = @_;
my $srch = search($self) or return;
# favor the Message-ID we used for the NNTP article number:
- my $mm = mm($self) or return;
- my $num = $mm->num_for($mid);
- $srch->lookup_article($num);
+ my $num = mid2num($self, $mid);
+ defined $num ? $srch->lookup_article($num) : undef;
}
sub msg_by_mid ($$;$) {
return $ret if $ret;
$ctx->{mid} = $mid;
- if ($mid =~ /\A[a-f0-9]{40}\z/) {
- # this is horiffically wasteful for legacy URLs:
- if ($mid = mid2blob($ctx)) {
- require Email::Simple;
- use PublicInbox::MID qw/mid_clean/;
- my $s = Email::Simple->new($mid);
- $ctx->{mid} = mid_clean($s->header('Message-ID'));
- }
+ my $ibx = $ctx->{-inbox};
+ if ($mid =~ m!\A([a-f0-9]{2})([a-f0-9]{38})\z!) {
+ my ($x2, $x38) = ($1, $2);
+ # this is horrifically wasteful for legacy URLs:
+ my $str = $ctx->{-inbox}->msg_by_path("$x2/$x38") or return;
+ require Email::Simple;
+ my $s = Email::Simple->new($str);
+ $mid = PublicInbox::MID::mid_clean($s->header('Message-ID'));
+ return r301($ctx, $inbox, $mid);
}
undef;
}
}
}
-# just returns a string ref for the blob in the current ctx
-sub mid2blob {
- my ($ctx) = @_;
- $ctx->{-inbox}->msg_by_mid($ctx->{mid});
-}
-
# /$INBOX/$MESSAGE_ID/raw -> raw mbox
sub get_mid_txt {
my ($ctx) = @_;
}
use_ok 'PublicInbox::Import';
use_ok 'PublicInbox::Git';
+my @ls;
foreach my $mod (@mods) { use_ok $mod; }
{
$im->done;
my $rev = `git --git-dir="$maindir" rev-list HEAD`;
like($rev, qr/\A[a-f0-9]{40}/, "good revision committed");
+ @ls = `git --git-dir="$maindir" ls-tree -r --name-only HEAD`;
+ chomp @ls;
}
my $app = eval {
local $ENV{PI_CONFIG} = $pi_config;
"$sfx redirected to /mbox.gz");
});
}
+ test_psgi($app, sub {
+ my ($cb) = @_;
+ # for a while, we used to support /$INBOX/$X40/
+ # when we "compressed" long Message-IDs to SHA-1
+ # Now we're stuck supporting them forever :<
+ foreach my $path (@ls) {
+ $path =~ tr!/!!d;
+ my $from = "http://example.com/test/$path/";
+ my $res = $cb->(GET($from));
+ is(301, $res->code, 'is permanent redirect');
+ like($res->header('Location'),
+ qr!/test/blah\@example\.com/!,
+ 'redirect from x40 MIDs works');
+ }
+ });
}
done_testing();