]> Sergey Matveev's repositories - public-inbox.git/commitdiff
linkify: support adding "(raw)" link for Message-IDs
authorEric Wong <e@80x24.org>
Thu, 24 Oct 2019 00:12:39 +0000 (00:12 +0000)
committerEric Wong <e@80x24.org>
Mon, 28 Oct 2019 10:49:11 +0000 (10:49 +0000)
And use it for the per-message permalink display.

lib/PublicInbox/Linkify.pm
lib/PublicInbox/View.pm

index 5b83742c14b36ace1e62790b20d417e0971dbc87..af9be3ff1632be1d8f7ede077f982c55501a782e 100644 (file)
@@ -92,7 +92,7 @@ sub linkify_2 {
 # single pass linkification of <Message-ID@example.com> within $str
 # with $pfx being the URL prefix
 sub linkify_mids {
-       my ($self, $pfx, $str) = @_;
+       my ($self, $pfx, $str, $raw) = @_;
        $$str =~ s!<([^>]+)>!
                my $msgid = PublicInbox::Hval->new_msgid($1);
                my $html = $msgid->as_html;
@@ -102,15 +102,17 @@ sub linkify_mids {
                # salt this, as this could be exploited to show
                # links in the HTML which don't show up in the raw mail.
                my $key = sha1_hex($html . $SALT);
-               $self->{$key} = [ $href, $html ];
-               '<PI-LINK-'. $key . '>';
+               my $repl = qq(&lt;<a\nhref="$pfx/$href/">$html</a>&gt;);
+               $repl .= qq{ (<a\nhref="$pfx/$href/raw">raw</a>)} if $raw;
+               $self->{$key} = $repl;
+               'PI-LINK-'. $key;
                !ge;
        $$str = ascii_html($$str);
        $$str =~ s!\bPI-LINK-([a-f0-9]{40})\b!
                my $key = $1;
                my $repl = $_[0]->{$key};
                if (defined $repl) {
-                       "<a\nhref=\"$pfx/$repl->[0]/\">$repl->[1]</a>";
+                       $repl;
                } else {
                        # false positive or somebody tried to mess with us
                        $key;
index ff55596d49bac1235446a2b14aeb2d016f5f9049..00bf38a9590bee6cb3cd57bb69d06b901eeedb65 100644 (file)
@@ -691,14 +691,11 @@ sub _msg_html_prepare {
                $rv .= "Message-ID: &lt;$mhtml&gt; ";
                $rv .= "(<a\nhref=\"raw\">raw</a>)\n";
        } else {
-               foreach (@$mids) {
-                       my $mid = PublicInbox::Hval->new_msgid($_);
-                       my $mhtml = $mid->as_html;
-                       my $href = $mid->{href};
-                       $rv .= "Message-ID: ";
-                       $rv .= "&lt;<a\nhref=\"../$href/\">$mhtml</a>&gt; ";
-                       $rv .= "(<a\nhref=\"../$href/raw\">raw</a>)\n";
-               }
+               my $lnk = PublicInbox::Linkify->new;
+               my $s = '';
+               $s .= "Message-ID: $_\n" for ($hdr->header_raw('Message-ID'));
+               $lnk->linkify_mids('..', \$s, 1);
+               $rv .= $s;
        }
        $rv .= _parent_headers($hdr, $over);
        $rv .= "\n";