1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
| | #!perl -w
# Copyright (C) all contributors <meta@public-inbox.org>
# License: AGPL-3.0+ <https://www.gnu.org/licenses/agpl-3.0.txt>
use v5.12;
use PublicInbox::TestCommon;
use PublicInbox::Eml;
my @mods = qw(DBD::SQLite HTTP::Request::Common Plack::Test
URI::Escape Plack::Builder);
require_git 2.6;
require_mods(@mods);
use_ok($_) for @mods;
use_ok 'PublicInbox::WWW';
my $msgs = <<'';
F1V5OR6NMF.3M649JTLO9IXD@tux.localdomain/hehe1"'<foo
F1V5NB0PTU.3U0DCVGAJ750Z@tux.localdomain"'<>/foo
F1V5NB0PTU.3U0DCVGAJ750Z@tux&.ampersand
F1V5MIHGCU.2ABINKW6WBE8N@tux.localdomain/raw
F1V5LF9D9C.2QT5PGXZQ050E@tux.localdomain/t.atom
F1V58X3CMU.2DCCVAKQZGADV@tux.localdomain/../../../../foo
F1TVKINT3G.2S6I36MXMHYG6@tux.localdomain" onclick="alert(1)"
my @mids = split(/\n/, $msgs);
my $ibx = create_inbox 'bad-mids', version => 2, indexlevel => 'basic', sub {
my ($im) = @_;
my $i = 0;
for my $mid (@mids) {
$im->add(PublicInbox::Eml->new(<<"")) or BAIL_OUT;
Subject: test
Message-ID: <$mid>
From: a\@example.com
To: b\@example.com
Date: Fri, 02 Oct 1993 00:00:0$i +0000
$i++;
}
};
my $tmpdir = tmpdir;
my $config = cfg_new $tmpdir, <<EOM;
[publicinbox "bad-mids"]
address = $ibx->{-primary_address}
inboxdir = $ibx->{inboxdir}
EOM
my $www = PublicInbox::WWW->new($config);
test_psgi(sub { $www->call(@_) }, sub {
my ($cb) = @_;
my $res = $cb->(GET('/bad-mids/'));
is($res->code, 200, 'got 200 OK listing');
my $raw = $res->content;
foreach my $mid (@mids) {
ok(index($raw, $mid) < 0, "escaped $mid");
}
my (@xmids) = ($raw =~ m!\bhref="([^"]+?)/T/#u"!sg);
is(scalar(@xmids), scalar(@mids),
'got escaped links to all messages');
@xmids = reverse @xmids;
my %uxs = ( gt => '>', lt => '<' );
foreach my $i (0..$#xmids) {
my $uri = $xmids[$i];
$uri =~ s/&#([0-9]+);/sprintf("%c", $1)/sge;
$uri =~ s/&(lt|gt);/$uxs{$1}/sge;
$res = $cb->(GET("/bad-mids/$uri/raw"));
is($res->code, 200, 'got 200 OK raw message '.$uri);
like($res->content, qr/Message-ID: <\Q$mids[$i]\E>/s,
'retrieved correct message');
}
});
done_testing;
|