about summary refs log tree commit homepage
path: root/lib/PublicInbox/WWW.pm
diff options
context:
space:
mode:
Diffstat (limited to 'lib/PublicInbox/WWW.pm')
-rw-r--r--lib/PublicInbox/WWW.pm14
1 files changed, 7 insertions, 7 deletions
diff --git a/lib/PublicInbox/WWW.pm b/lib/PublicInbox/WWW.pm
index 251979d5..13b66ee6 100644
--- a/lib/PublicInbox/WWW.pm
+++ b/lib/PublicInbox/WWW.pm
@@ -42,15 +42,17 @@ sub run {
         PublicInbox::WWW->new->call($req->env);
 }
 
+# PATH_INFO is decoded, and we want the undecoded original
 my %path_re_cache;
-
-sub path_re ($) {
-        my $sn = $_[0]->{SCRIPT_NAME};
-        $path_re_cache{$sn} ||= do {
+sub path_info_raw ($) {
+        my ($env) = @_;
+        my $sn = $env->{SCRIPT_NAME};
+        my $re = $path_re_cache{$sn} ||= do {
                 $sn = '/'.$sn unless index($sn, '/') == 0;
                 $sn =~ s!/\z!!;
                 qr!\A(?:https?://[^/]+)?\Q$sn\E(/[^\?\#]+)!;
         };
+        $env->{REQUEST_URI} =~ $re ? $1 : $env->{PATH_INFO};
 }
 
 sub call {
@@ -67,9 +69,7 @@ sub call {
                 $k => $v;
         } split(/[&;]+/, $env->{QUERY_STRING});
 
-        # avoiding $env->{PATH_INFO} here since that's already decoded
-        my ($path_info) = ($env->{REQUEST_URI} =~ path_re($env));
-        $path_info //= $env->{PATH_INFO};
+        my $path_info = path_info_raw($env);
         my $method = $env->{REQUEST_METHOD};
 
         if ($method eq 'POST') {