From 5cd0eab98e088720e6090e8533b1fb8e52a8a214 Mon Sep 17 00:00:00 2001 From: Jesse Luehrs Date: Thu, 6 Jan 2011 12:53:46 -0600 Subject: handle env hashes too this is getting uglier and uglier - need to rethink this i think --- lib/Plack/Client.pm | 11 +++++++++-- 1 file changed, 9 insertions(+), 2 deletions(-) (limited to 'lib') diff --git a/lib/Plack/Client.pm b/lib/Plack/Client.pm index d97f44c..5a2abb4 100644 --- a/lib/Plack/Client.pm +++ b/lib/Plack/Client.pm @@ -41,8 +41,15 @@ sub request { my $scheme = $req->uri->scheme; my $app; if ($scheme eq 'psgi-local') { - $req->uri->path('/') unless length $req->uri->path; - $app = $self->app_for($req->uri->authority); + if ($req->isa('Plack::Request')) { + $req->env->{REQUEST_URI} = '/' unless length $req->request_uri; + } + else { + $req->uri->path('/') unless length $req->uri->path; + } + my $app_name = $req->uri->authority; + $app_name =~ s/:.*//; + $app = $self->app_for($app_name); $app = Plack::Middleware::ContentLength->wrap($app); } elsif ($scheme eq 'http' || $scheme eq 'https') { -- cgit v1.2.3-54-g00ecf