X-Git-Url: http://git.freeside.biz/gitweb/?p=freeside.git;a=blobdiff_plain;f=htetc%2Fhandler.pl;h=cac90044d00d0f80252ddd6c63e0931c42b4b756;hp=29e759a6816e8c3e0536359a0057a7982108c0d4;hb=32e8c2a2a58428acd539d880357c76720334c011;hpb=0bdec843e4a9bb7f947c9ba980a40f7bf37020fb diff --git a/htetc/handler.pl b/htetc/handler.pl index 29e759a68..cac90044d 100644 --- a/htetc/handler.pl +++ b/htetc/handler.pl @@ -34,7 +34,9 @@ my $interp = new HTML::Mason::Interp (parser=>$parser, data_dir=>'/home/ivan/freeside_current/masondata', out_mode=>'stream', ); -my $ah = new HTML::Mason::ApacheHandler (interp=>$interp); +my $ah = new HTML::Mason::ApacheHandler ( interp => $interp, + #auto_send_headers => 0, + ); # Activate the following if running httpd as root (the normal case). # Resets ownership of all files created by Mason at startup. @@ -68,7 +70,7 @@ sub handler use FS::Record qw(qsearch qsearchs fields dbdef); use FS::Conf; use FS::CGI qw(header menubar popurl table itable ntable idiot eidiot - small_custviewm myexit); + small_custview myexit); use FS::agent; use FS::agent_type; @@ -101,11 +103,30 @@ sub handler use FS::svc_www; use FS::type_pkgs; + *CGI::redirect = sub { + my( $self, $location ) = @_; + + #http://www.masonhq.com/docs/faq/#how_do_i_do_an_external_redirect + $m->clear_buffer; + # The next two lines are necessary to stop Apache from re-reading + # POSTed data. + $r->method('GET'); + $r->headers_in->unset('Content-length'); + $r->content_type('text/html'); + #$r->err_header_out('Location' => $location); + $r->header_out('Location' => $location); + $r->header_out('Content-Type' => 'text/html'); + $m->abort(302); + + ''; + }; + $cgi = new CGI; &cgisuidsetup($cgi); #&cgisuidsetup($r); $p = popurl(2); } + $r->content_type('text/html'); #eorar @@ -113,10 +134,12 @@ sub handler $headers->{'Pragma'} = $headers->{'Cache-control'} = 'no-cache'; #$r->no_cache(1); $headers->{'Expires'} = '0'; - + +# $r->send_http_header; + my $status = $ah->handle_request($r); - - return $status; + + $status; } 1;