]> Sergey Matveev's repositories - public-inbox.git/commitdiff
lei_external: don't treat IPv6 URLs as globs
authorEric Wong <e@80x24.org>
Wed, 24 Feb 2021 23:37:17 +0000 (05:37 +0600)
committerEric Wong <e@80x24.org>
Thu, 25 Feb 2021 09:47:34 +0000 (09:47 +0000)
IPv6 addresses are hexadecimals and colons inside brackets, so
add some DWIM-ery to ensure we don't attempt to treat addresses
like "http://[dead:beef]/foo/" as a glob.

lib/PublicInbox/LeiExternal.pm
t/lei_external.t

index 0cc84ccaec3b6b4823a5cbd260c6687823968b04..47791d4e21ba0d2d67e48f99aadfbcce13752ce5 100644 (file)
@@ -54,6 +54,12 @@ sub glob2re {
        my $p = '';
        my $in_bracket = 0;
        my $qm = 0;
+       my $schema_host_port = '';
+
+       # don't glob URL-looking things that look like IPv6
+       if ($re =~ s!\A([a-z0-9\+]+://\[[a-f0-9\:]+\](?::[0-9]+)?/)!!i) {
+               $schema_host_port = quotemeta $1; # "http://[::1]:1234"
+       }
        my $changes = ($re =~ s!(.)!
                $re_map{$p eq '\\' ? '' : do {
                        if ($1 eq '[') { ++$in_bracket }
@@ -69,7 +75,7 @@ sub glob2re {
                        (my $in_braces = $2) =~ tr!,!|!;
                        $1."($in_braces)";
                        /sge);
-       ($changes - $qm) ? $re : undef;
+       ($changes - $qm) ? $schema_host_port.$re : undef;
 }
 
 # get canonicalized externals list matching $loc
index 78f71658529745a99b41d6bc3ef379d2ea49ca90..51d0af5c6333e52d436ed6722791e5bfab229857 100644 (file)
@@ -17,6 +17,7 @@ is($canon->('/this//path/'), '/this/path', 'extra slashes gone');
 is($canon->('/ALL/CAPS'), '/ALL/CAPS', 'caps preserved');
 
 my $glob2re = $cls->can('glob2re');
+is($glob2re->('http://[::1]:1234/foo/'), undef, 'IPv6 URL not globbed');
 is($glob2re->('foo'), undef, 'plain string unchanged');
 is_deeply($glob2re->('[f-o]'), '[f-o]' , 'range accepted');
 is_deeply($glob2re->('*'), '[^/]*?' , 'wildcard accepted');