X-Git-Url: http://git.shadowcat.co.uk/gitweb/gitweb.cgi?a=blobdiff_plain;f=lib%2FCatalyst%2FEngine%2FFastCGI.pm;h=85b360c193833f21647b5427e42134258016856f;hb=ea72fece19fee2a788a7e9cab6076392fdd674a0;hp=b480c9ad7bb6d19c818ac5ffa7ff1f8a49a14c1a;hpb=52c5e714ef4dd079008b4e736eca4e2b98e22207;p=catagits%2FCatalyst-Runtime.git diff --git a/lib/Catalyst/Engine/FastCGI.pm b/lib/Catalyst/Engine/FastCGI.pm index b480c9a..85b360c 100644 --- a/lib/Catalyst/Engine/FastCGI.pm +++ b/lib/Catalyst/Engine/FastCGI.pm @@ -234,9 +234,12 @@ sub _fix_env if ( $env->{SERVER_SOFTWARE} =~ /lighttpd/ ) { $env->{PATH_INFO} ||= delete $env->{SCRIPT_NAME}; } + elsif ( $env->{SERVER_SOFTWARE} =~ /^nginx/ ) { + my $script_name = $env->{SCRIPT_NAME}; + $env->{PATH_INFO} =~ s/^$script_name//g; + } # Fix the environment variables PATH_INFO and SCRIPT_NAME when running # under IIS - # FIXME - How does this handle %7F? elsif ( $env->{SERVER_SOFTWARE} =~ /IIS\/[6-9]\.[0-9]/ ) { my @script_name = split(m!/!, $env->{PATH_INFO}); my @path_translated = split(m!/|\\\\?!, $env->{PATH_TRANSLATED}); @@ -460,7 +463,7 @@ The server configuration block should look roughly like: fastcgi_param CONTENT_TYPE $content_type; fastcgi_param CONTENT_LENGTH $content_length; - fastcgi_param PATH_INFO $fastcgi_script_name; + fastcgi_param PATH_INFO /; fastcgi_param SCRIPT_NAME $fastcgi_script_name; fastcgi_param REQUEST_URI $request_uri; fastcgi_param DOCUMENT_URI $document_uri; @@ -487,9 +490,9 @@ simply include that file. =head3 Non-root configuration -If you properly specify the PATH_INFO and SCRIPT_NAME parameters your -application will be accessible at any path. The SCRIPT_NAME variable is the -prefix of your application, and PATH_INFO would be everything in addition. +If you properly specify the PATH_INFO and SCRIPT_NAME parameters your +application will be accessible at any path. The PATH_INFO variable is the +prefix of your application, and SCRIPT_NAME would be everything in addition. As an example, if your application is rooted at /myapp, you would configure: