]> Sergey Matveev's repositories - public-inbox.git/blobdiff - lib/PublicInbox/WWW.pm
www: fix redirection loops
[public-inbox.git] / lib / PublicInbox / WWW.pm
index b4c050b1069286e7bfb33e5b4e38a19f3b1fcc7e..d5635d849fcea047c0402f22cacbdab87ce913ea 100644 (file)
@@ -47,7 +47,9 @@ sub run {
 
        # in case people leave off the trailing slash:
        } elsif ($path_info =~ m!$LISTNAME_RE/$MID_RE/(f|T|t)\z!o) {
-               r301($ctx, $1, $2, $3 eq 't' ? 't/#u' : $3);
+               my ($listname, $mid, $suffix) = ($1, $2, $3);
+               $suffix .= $suffix =~ /\A[tT]\z/ ? '/#u' : '/';
+               r301($ctx, $listname, $mid, $suffix);
 
        # convenience redirects order matters
        } elsif ($path_info =~ m!$LISTNAME_RE/([^/]{2,})\z!o) {
@@ -198,6 +200,7 @@ sub get_thread {
 
 sub self_url {
        my ($cgi) = @_;
+                                               # Plack::Request
        ref($cgi) eq 'CGI' ? $cgi->self_url : $cgi->uri->as_string;
 }
 
@@ -362,7 +365,7 @@ sub r301 {
        if (ref($cgi) eq 'CGI') {
                $url = $cgi->url(-base) . '/';
                $qs = $cgi->query_string;
-       } else {
+       } else { # Plack::Request
                $url = $cgi->base->as_string;
                $qs = $cgi->env->{QUERY_STRING};
        }