ASP4
view release on metacpan or search on metacpan
lib/ASP4/Response.pm view on Meta::CPAN
{
my $s = shift;
my $out = $s->context->headers_out;
map {{
$_ => $out->{$_}
}} keys %$out;
}# end Headers()
sub Redirect
{
my ($s, $url) = @_;
$s->Clear;
$s->Status( 301 );
$s->Expires( "-24H" )
unless $s->Expires;
$s->SetHeader( Location => $url );
$s->End;
return $s->Status;
}# end Redirect()
sub Declined { -1 }
sub Include
{
my ($s, $file, $args) = @_;
$s->Write( $s->_subrequest( $file, $args ) );
}# end Include()
sub TrapInclude
{
my ($s, $file, $args) = @_;
return $s->_subrequest( $file, $args );
}# end TrapInclude()
sub _subrequest
{
my ($s, $file, $args) = @_;
my $context = ASP4::HTTPContext->new( is_subrequest => 1 );
my $original_r = $s->context->r;
my $root = $s->context->config->web->www_root;
my $cgi = $s->context->cgi;
(my $uri = $file) =~ s/^\Q$root\E//;
my $r = ASP4::Mock::RequestRec->new(
uri => $uri,
args => $original_r->args,
);
SCOPE: {
local $ASP4::HTTPContext::_instance = $context;
local $ENV{SCRIPT_NAME} = $uri;
local $ENV{SCRIPT_FILENAME} = $file;
$context->setup_request( $r, $cgi );
$context->execute( $args, 1 );
};
return $context->r->buffer;
}# end _subrequest()
#sub _subrequest
#{
# my ($s, $file, $args) = @_;
#
# $s->context->add_buffer();
# my $original_r = $s->context->r;
# my $root = $s->context->config->web->www_root;
# (my $uri = $file) =~ s/^\Q$root\E//;
# my $r = ASP4::Mock::RequestRec->new(
# uri => $uri,
# args => $original_r->args,
# );
# local $ENV{SCRIPT_NAME} = $uri;
# local $ENV{SCRIPT_FILENAME} = $file;
# my $original_status = $s->Status();
# $s->context->setup_request( $r, $s->context->cgi );
# $s->context->execute( $args, 1 );
# $s->Flush;
# $s->Status( $original_status );
# my $buffer = $s->context->purge_buffer();
# $s->context->{r} = $original_r;
# $s->context->did_end( 0 );
# return $r->buffer;
#}# end _subrequest()
sub DESTROY
{
my $s = shift;
undef(%$s);
}# end DESTROY()
1;# return true:
=pod
=head1 NAME
ASP4::Response - Interface to the outgoing HTTP response
=head1 SYNOPSIS
$Response->ContentType("text/html");
$Response->Status( 200 );
$Response->Clear();
$Response->Flush();
$Response->Write("Hello, World!");
$Response->AddHeader( 'x-awesomeness' => '100%' );
$Response->SetHeader( 'x-velocity' => '100MPH' );
# Expires in the future:
$Response->Expires( '30M' ); # 30 minutes from now
$Response->Expires( '30H' ); # 30 hours from now
$Response->Expires( '30D' ); # 30 days from now
# Expires in the past:
$Response->Expires( '-30M' ); # 30 minutes ago
$Response->Expires( '-30H' ); # 30 hours ago
$Response->Expires( '-30D' ); # 30 days ago
$Response->SetCookie(
# Required parameters:
name => "customer-email",
value => $Form->{email},
# The rest are optional:
expires => '30D', # 30 days
path => '/',
domain => '.mysite.com',
);
lib/ASP4/Response.pm view on Meta::CPAN
C<%args> B<must> contain the following:
=over 4
=item * name
A string - the name of the cookie.
=item * value
The value of the cookie.
=back
Other parameters are:
=over 4
=item * expires
Can be in one of the following formats:
=over 8
=item * 30B<M>
Minutes - how many minutes from "now" calculated as C<time() + (30 * 60)>
Example:
expires => '30M'
expires => '-5M' # 5 minutes ago
=item * 2B<H>
Hours - how many hours from "now" calculated as C<time() + (2 * 60 * 60)>
Example:
expires => '2H' # 2 hours
expires => '12H' # 12 Hours
=item * 7B<D>
Days - how many days from "now" calculated as C<time() + (7 * 60 * 60 * 24)>
Example:
expires => '7D' # A week
expires => '30D' # A month
=back
=item * path
Defaults to "C</>" - you can restrict the "path" that the cookie will apply to.
=item * domain
Defaults to whatever you set your config->data_connections->session->cookie_domain to
in your asp4-config.json. Otherwise defaults to C<$ENV{HTTP_HOST}>.
You can override the defaults by passing in a domain, but the browser may not accept
other domains. See L<http://www.ietf.org/rfc/rfc2109.txt> for details.
=back
=head2 Redirect( $url )
Causes the following HTTP header to be sent:
Status: 301 Moved
Location: $url
=head2 Include( $path [, \%args ] )
Executes the ASP script at C<$path> and includes its output. Additional C<\%args>
may be passed along to the include.
The passed-in args are accessible to the include like this:
<%
my ($self, $context, $args) = @_;
# Args is a hashref:
%>
=head2 TrapInclude( $path [, \%args ] )
Executes the ASP script at C<$path> and returns its output. Additional C<\%args>
may be passed along to the include.
The passed-in args are accessible to the include like this:
<%
my ($self, $context, $args) = @_;
# Args is a hashref:
%>
=head1 BUGS
It's possible that some bugs have found their way into this release.
Use RT L<http://rt.cpan.org/NoAuth/Bugs.html?Dist=ASP4> to submit bug reports.
=head1 HOMEPAGE
Please visit the ASP4 homepage at L<http://0x31337.org/code/> to see examples
of ASP4 in action.
=cut
( run in 0.967 second using v1.01-cache-2.11-cpan-39bf76dae61 )