]> Sergey Matveev's repositories - public-inbox.git/commitdiff
www: tighten up allowable filenames for attachments
authorEric Wong <e@80x24.org>
Thu, 19 May 2016 22:02:56 +0000 (22:02 +0000)
committerEric Wong <e@80x24.org>
Thu, 19 May 2016 22:02:56 +0000 (22:02 +0000)
Having a file start with '.' or '-' can be confusing
and for users, so do not allow it.

lib/PublicInbox/View.pm
lib/PublicInbox/WWW.pm
t/psgi_attach.t

index ec5f39076eccc64d15d87699ca8919e2b4d3200f..21949812d5789131bb6bba536ed582e334c38edb 100644 (file)
@@ -261,7 +261,7 @@ sub attach_link ($$$$) {
        $desc = $fn unless defined $desc;
        $desc = '' unless defined $desc;
        my $sfn;
-       if (defined $fn && $fn =~ /\A[\w\.-]+[a-zA-Z0-9]\z/) {
+       if (defined $fn && $fn =~ /\A[[:alnum:]][\w\.-]+[[:alnum:]]\z/) {
                $sfn = $fn;
        } elsif ($ct eq 'text/plain') {
                $sfn = 'a.txt';
index 10c2e7caee36e2a46bea6a9d43a1fa41603937bb..5b4d6c185722bdeb98f408acabb258687b40123b 100644 (file)
@@ -23,7 +23,7 @@ use PublicInbox::GitHTTPBackend;
 our $INBOX_RE = qr!\A/([\w\.\-]+)!;
 our $MID_RE = qr!([^/]+)!;
 our $END_RE = qr!(T/|t/|R/|t\.mbox(?:\.gz)?|t\.atom|raw|)!;
-our $ATTACH_RE = qr!(\d[\.\d]*)-([\w\.-]+[a-zA-Z0-9])!i;
+our $ATTACH_RE = qr!(\d[\.\d]*)-([[:alnum:]][\w\.-]+[[:alnum:]])!i;
 
 sub new {
        my ($class, $pi_config) = @_;
index 43018e85d1ce6bf3fec6d41cfebc356aec822650..ef116c6af13f63fab9368ea91ed13ac2b39da5c0 100644 (file)
@@ -36,6 +36,7 @@ my $im = PublicInbox::Import->new($git, 'test', $addr);
        my $qp = "abcdef=g\n==blah\n";
        my $b64 = 'b64'.$buf."\n";
        my $txt = "plain\ntext\npass\nthrough\n";
+       my $dot = "dotfile\n";
        my $parts = [
                Email::MIME->create(
                        attributes => {
@@ -57,6 +58,12 @@ my $im = PublicInbox::Import->new($git, 'test', $addr);
                                content_type => 'text/plain',
                        },
                        body => $txt),
+               Email::MIME->create(
+                       attributes => {
+                               filename => '.dotfile',
+                               content_type => 'text/plain',
+                       },
+                       body => $dot),
        ];
        my $mime = Email::MIME->create(
                parts => $parts,
@@ -76,7 +83,8 @@ my $im = PublicInbox::Import->new($git, 'test', $addr);
                $res = $cb->(GET('/test/Z%40B/'));
                my @href = ($res->content =~ /^href="([^"]+)"/gms);
                @href = grep(/\A[\d\.]+-/, @href);
-               is_deeply([qw(1-queue-pee 2-bayce-sixty-four 3-noop.txt)],
+               is_deeply([qw(1-queue-pee 2-bayce-sixty-four 3-noop.txt
+                               4-a.txt)],
                        \@href, 'attachment links generated');
 
                $res = $cb->(GET('/test/Z%40B/1-queue-pee'));
@@ -97,6 +105,13 @@ my $im = PublicInbox::Import->new($git, 'test', $addr);
                        'plain text almost matches');
                like($txt_res, qr/\n\z/s, 'trailing newline exists in text');
                is(index($txt_res, $txt), 0, 'plain text not truncated');
+
+               $res = $cb->(GET('/test/Z%40B/4-a.txt'));
+               my $dot_res = $res->content;
+               ok(length($dot_res) >= length($dot), 'dot almost matches');
+               $res = $cb->(GET('/test/Z%40B/4-any-filename.txt'));
+               is($res->content, $dot_res, 'user-specified filename is OK');
+
        });
 }
 done_testing();