- my $self = shift;
- $self->{path} = $self->{cgi}->url(-absolute=>1, -path_info=>1);
- my $loc = $self->{cgi}->url(-absolute=>1);
- no warnings 'uninitialized';
- $self->{path} =~ s/^($loc)?\///;
- $self->parse_path;
- $self->{params} = { $self->{cgi}->Vars };
- $self->{query} = { $self->{cgi}->Vars };
+ my $self = shift;
+ my $cgi = $self->{cgi};
+
+ # Reconstruct the request headers (as far as this is possible)
+ $self->headers_in(Maypole::Headers->new);
+ for my $http_header ($cgi->http) {
+ (my $field_name = $http_header) =~ s/^HTTPS?_//;
+ $self->headers_in->set($field_name => $cgi->http($http_header));
+ }
+
+ $self->{path} = $cgi->url( -absolute => 1, -path_info => 1 );
+ my $loc = $cgi->url( -absolute => 1 );
+ no warnings 'uninitialized';
+ $self->{path} .= '/' if $self->{path} eq $loc;
+ $self->{path} =~ s/^($loc)?\///;
+ $self->parse_path;
+ $self->parse_args;
+}
+
+sub parse_args {
+ my $self = shift;
+ my (%vars) = $self->{cgi}->Vars;
+ while ( my ( $key, $value ) = each %vars ) {
+ my @values = split "\0", $value;
+ $vars{$key} = @values <= 1 ? $values[0] : \@values;
+ }
+ $self->{params} = {%vars};
+ $self->{query} = {%vars};
+}
+
+# FIXME: use headers_in to gather host and other information?
+sub redirect_request {
+ my $self = shift;
+ my $redirect_url = $_[0];
+ my $status = "302";
+ if ($_[1]) {
+ my %args = @_;
+ if ($args{url}) {
+ $redirect_url = $args{url};
+ } else {
+ my $path = $args{path} || $self->{cgi}->url(-absolute => 1, -query=>1);
+ my $host = $args{domain};
+ ($host = $self->{cgi}->url(-base => 1)) =~ s/^https?:\/\///i unless ($host);
+ my $protocol = $args{protocol} || ($self->{cgi}->https()) ? 'https' : 'http';
+ $redirect_url = "${protocol}://${host}/${path}";
+ }
+ $status = $args{status} if ($args{status});
+ }
+
+ $self->headers_out->set('Status' => $status);
+ $self->headers_out->set('Location' => $redirect_url);
+
+ return;