X-Git-Url: http://git.freeside.biz/gitweb/?a=blobdiff_plain;f=rt%2Flib%2FRT%2FInterface%2FWeb%2FRequest.pm;h=b07048fda00a2fbf4f2706043ec58bde8a519aee;hb=HEAD;hp=84dd28dd672d0e0d10ff0f7a4e2e31c850f3b680;hpb=0fb307c305e4bc2c9c27dc25a3308beae3a4d33c;p=freeside.git diff --git a/rt/lib/RT/Interface/Web/Request.pm b/rt/lib/RT/Interface/Web/Request.pm index 84dd28dd6..b07048fda 100644 --- a/rt/lib/RT/Interface/Web/Request.pm +++ b/rt/lib/RT/Interface/Web/Request.pm @@ -2,7 +2,7 @@ # # COPYRIGHT: # -# This software is Copyright (c) 1996-2011 Best Practical Solutions, LLC +# This software is Copyright (c) 1996-2019 Best Practical Solutions, LLC # # # (Except where explicitly superseded by other copyright notices) @@ -51,57 +51,19 @@ package RT::Interface::Web::Request; use strict; use warnings; -our $VERSION = '0.30'; -use base qw(HTML::Mason::Request); +use HTML::Mason::PSGIHandler; +use base qw(HTML::Mason::Request::PSGI); +use Params::Validate qw(:all); sub new { my $class = shift; - - my $new_class = $HTML::Mason::ApacheHandler::VERSION ? - 'HTML::Mason::Request::ApacheHandler' : - $HTML::Mason::CGIHandler::VERSION ? - 'HTML::Mason::Request::CGI' : - 'HTML::Mason::Request'; - - $class->alter_superclass( $new_class ); - $class->valid_params( %{ $new_class->valid_params } ); + $class->valid_params( %{ $class->valid_params },cgi_request => { type => OBJECT, optional => 1 } ); return $class->SUPER::new(@_); } -# XXX TODO: This alter_superclass replaces teh funcitonality in Mason 1.39 -# with code which doesn't trigger a bug in Perl 5.10. -# (Perl 5.10.0 does NOT take kindly to having its @INC entries changed) -# http://rt.perl.org/rt3/Public/Bug/Display.html?id=54566 -# -# This routine can be removed when either: -# * RT depends on a version of mason which contains this fix -# * Perl 5.10.0 is not supported for running RT -sub alter_superclass { - my $class = shift; - my $new_super = shift; - my $isa_ref; - { no strict 'refs'; my @entries = @{$class."::ISA"}; $isa_ref = \@entries; } - - # handles multiple inheritance properly and preserve - # inheritance order - for ( my $x = 0; $x <= $#{$isa_ref} ; $x++ ) { - if ( $isa_ref->[$x]->isa('HTML::Mason::Request') ) { - my $old_super = $isa_ref->[$x]; - $isa_ref->[$x] = $new_super - if ( $old_super ne $new_super ); - last; - } - } - - { no strict 'refs'; @{$class."::ISA"} = @$isa_ref; } - $class->valid_params( %{ $class->valid_params } ); -} - =head2 callback -Method replaces deprecated component C. - Takes hash with optional C, C and C arguments, other arguments are passed throught to callback components. @@ -123,6 +85,12 @@ By default is false, otherwise runs callbacks only once per process of the server. Such callbacks can be used to fill structures. +=item ReturnComponentOutput + +By default, callback returns the status codes of all rendered components, and +prints the rendered components to STDOUT. If this argument is true, callback +returns the rendered components instead of printing them to STDOUT. + =back Searches for callback components in @@ -140,6 +108,7 @@ sub callback { my $name = delete $args{'CallbackName'} || 'Default'; my $page = delete $args{'CallbackPage'} || $self->callers(0)->path; + my $use_scomp = delete $args{'ReturnComponentOutput'} ? 1 : 0; unless ( $page ) { $RT::Logger->error("Couldn't get a page name for callbacks"); return; @@ -153,11 +122,7 @@ sub callback { unless ( $callbacks ) { $callbacks = []; my $path = "/Callbacks/*$page/$name"; - my @roots = map $_->[1], - $HTML::Mason::VERSION <= 1.28 - ? $self->interp->resolver->comp_root_array - : $self->interp->comp_root_array; - + my @roots = RT::Interface::Web->ComponentRoots; my %seen; @$callbacks = ( grep defined && length, @@ -176,10 +141,20 @@ sub callback { } my @rv; + my $scomp_out; foreach my $cb ( @$callbacks ) { - push @rv, scalar $self->comp( $cb, %args ); + if ( $use_scomp ) { + no warnings 'uninitialized'; + $scomp_out .= $self->scomp( $cb, %args ); + } else { + push @rv, scalar $self->comp( $cb, %args ); + } } - return @rv; + return $use_scomp ? $scomp_out : @rv; +} + +sub clear_callback_cache { + %cache = %called = (); } } @@ -204,4 +179,21 @@ sub request_path { return $path; } +=head2 abort + +Logs any recorded SQL statements for this request before calling the standard +abort. + +=cut + +sub abort { + my $self = shift; + RT::Interface::Web::LogRecordedSQLStatements( + RequestData => { + Path => $self->request_path, + }, + ); + return $self->SUPER::abort(@_); +} + 1;