[freeside-commits] freeside/htetc handler.pl,1.113,1.114

Ivan,,, ivan at wavetail.420.am
Mon Jul 21 11:58:46 PDT 2008


Update of /home/cvs/cvsroot/freeside/htetc
In directory wavetail.420.am:/tmp/cvs-serv26066/htetc

Modified Files:
	handler.pl 
Log Message:
add framework for running Mason components standalone

Index: handler.pl
===================================================================
RCS file: /home/cvs/cvsroot/freeside/htetc/handler.pl,v
retrieving revision 1.113
retrieving revision 1.114
diff -u -d -r1.113 -r1.114
--- handler.pl	25 Jun 2008 00:29:28 -0000	1.113
+++ handler.pl	21 Jul 2008 18:58:44 -0000	1.114
@@ -3,10 +3,10 @@
 package HTML::Mason;
 
 use strict;
-use vars qw($r);
-use HTML::Mason 1.27; #http://www.masonhq.com/?ApacheModPerl2Redirect
-use HTML::Mason::Interp;
-use HTML::Mason::Compiler::ToObject;
+use warnings;
+use FS::Mason qw( mason_interps );
+
+#use vars qw($r);
 
 # Bring in ApacheHandler, necessary for mod_perl integration.
 # Uncomment the second line (and comment the first) to use
@@ -16,59 +16,14 @@
 
 ###use Module::Refresh;###
 
-# List of modules that you want to use from components (see Admin
-# manual for details)
-#{  package HTML::Mason::Commands;
-#   use CGI;
-#}
-
-if ( %%%RT_ENABLED%%% ) {
- eval '
-   use lib ( "/opt/rt3/local/lib", "/opt/rt3/lib" );
-   use RT;
-   use vars qw($Nobody $SystemUser);
-   RT::LoadConfig();
- ';
- die $@ if $@;
-}
-
 # Create Mason objects
 
-my %interp = (
-  request_class        => 'HTML::Mason::Request::ApacheHandler',
-  data_dir             => '%%%MASONDATA%%%',
-  error_mode           => 'output',
-  error_format         => 'html',
-  ignore_warnings_expr => '.',
-  comp_root            => [
-                            [ 'freeside' => '%%%FREESIDE_DOCUMENT_ROOT%%%'    ],
-                            [ 'rt'       => '%%%FREESIDE_DOCUMENT_ROOT%%%/rt' ],
-                          ],
-);
-
-my $fs_interp = new HTML::Mason::Interp (
-  %interp,
-  escape_flags => { 'js_string' => sub {
-                      #${$_[0]} =~ s/(['\\\n])/'\\'.($1 eq "\n" ? 'n' : $1)/ge;
-                      ${$_[0]} =~ s/(['\\])/\\$1/g;
-                      ${$_[0]} =~ s/\n/\\n/g;
-                      ${$_[0]} = "'". ${$_[0]}. "'";
-                    }
-                  },
-);
-
-my $rt_interp = new HTML::Mason::Interp (
-  %interp,
-  escape_flags => { 'h' => \&RT::Interface::Web::EscapeUTF8 },
-  compiler     => HTML::Mason::Compiler::ToObject->new(
-                    default_escape_flags => 'h',
-                    allow_globals        => [qw(%session)],
-                  ),
-);
+my( $fs_interp, $rt_interp ) = mason_interps('apache');
 
 my $ah = new HTML::Mason::ApacheHandler (
-  interp      => $fs_interp,
-  args_method => 'CGI', #(and FS too)
+  interp        => $fs_interp,
+  request_class => 'FS::Mason::Request',
+  args_method   => 'CGI', #(and FS too)
 );
 
 # Activate the following if running httpd as root (the normal case).
@@ -78,7 +33,8 @@
 
 sub handler
 {
-    ($r) = @_;
+    #($r) = @_;
+    my $r = shift;
 
     # If you plan to intermix images in the same directory as
     # components, activate the following to prevent Mason from
@@ -86,289 +42,6 @@
     #
     #return -1 if $r->content_type && $r->content_type !~ m|^text/|i;
 
-    #rar
-    { package HTML::Mason::Commands;
-      use strict;
-      use vars qw( $cgi $p $fsurl);
-      use vars qw( %session );
-      use CGI 3.29 qw(-private_tempfiles); #3.29 to fix RT attachment problems
-      #use CGI::Carp qw(fatalsToBrowser);
-      use CGI::Cookie;
-      use List::Util qw( max min );
-      use Data::Dumper;
-      use Date::Format;
-      use Date::Parse;
-      use Time::Local;
-      use Time::Duration;
-      use DateTime;
-      use DateTime::Format::Strptime;
-      use Lingua::EN::Inflect qw(PL);
-      use Tie::IxHash;
-      use URI::URL;
-      use URI::Escape;
-      use HTML::Entities;
-      use HTML::TreeBuilder;
-      use HTML::FormatText;
-      use JSON;
-      use MIME::Base64;
-      use IO::Handle;
-      use IO::File;
-      use IO::Scalar;
-      #not actually using this yet anyway...# use IPC::Run3 0.036;
-      use Net::Whois::Raw qw(whois);
-      if ( $] < 5.006 ) {
-        eval "use Net::Whois::Raw 0.32 qw(whois)";
-        die $@ if $@;
-      }
-      use Text::CSV_XS;
-      use Spreadsheet::WriteExcel;
-      use Business::CreditCard 0.30; #for mask-aware cardtype()
-      use NetAddr::IP;
-      use String::Approx qw(amatch);
-      use Chart::LinesPoints;
-      use Chart::Mountain;
-      use Color::Scheme;
-      use HTML::Widgets::SelectLayers 0.07; #should go away in favor of
-                                            #selectlayers.html
-      use Locale::Country;
-      use Business::US::USPS::WebTools::AddressStandardization;
-      use FS;
-      use FS::UID qw( adminsuidsetup cgisuidsetup getotaker
-                      dbh datasrc driver_name
-                    );
-      use FS::Record qw( qsearch qsearchs fields dbdef
-                        str2time_sql str2time_sql_closing
-                       );
-      use FS::Conf;
-      use FS::CGI qw(header menubar popurl rooturl table itable ntable idiot
-                     eidiot myexit http_header);
-      use FS::UI::Web qw(svc_url);
-      use FS::UI::Web::small_custview qw(small_custview);
-      use FS::UI::bytecount;
-      use FS::Msgcat qw(gettext geterror);
-      use FS::Misc qw( send_email send_fax states_hash counties state_label );
-      use FS::Report::Table::Monthly;
-      use FS::TicketSystem;
-
-      use FS::agent;
-      use FS::agent_type;
-      use FS::domain_record;
-      use FS::cust_bill;
-      use FS::cust_bill_pay;
-      use FS::cust_credit;
-      use FS::cust_credit_bill;
-      use FS::cust_main qw(smart_search);
-      use FS::cust_main_county;
-      use FS::cust_pay;
-      use FS::cust_pkg;
-      use FS::part_pkg_taxclass;
-      use FS::cust_pkg_reason;
-      use FS::cust_refund;
-      use FS::cust_credit_refund;
-      use FS::cust_pay_refund;
-      use FS::cust_svc;
-      use FS::nas;
-      use FS::part_bill_event;
-      use FS::part_event;
-      use FS::part_event_condition;
-      use FS::part_pkg;
-      use FS::part_referral;
-      use FS::part_svc;
-      use FS::part_svc_router;
-      use FS::part_virtual_field;
-      use FS::pay_batch;
-      use FS::pkg_svc;
-      use FS::port;
-      use FS::queue qw(joblisting);
-      use FS::raddb;
-      use FS::session;
-      use FS::svc_acct;
-      use FS::svc_acct_pop qw(popselector);
-      use FS::acct_rt_transaction;
-      use FS::svc_domain;
-      use FS::svc_forward;
-      use FS::svc_www;
-      use FS::router;
-      use FS::addr_block;
-      use FS::svc_broadband;
-      use FS::svc_external;
-      use FS::type_pkgs;
-      use FS::part_export;
-      use FS::part_export_option;
-      use FS::export_svc;
-      use FS::msgcat;
-      use FS::rate;
-      use FS::rate_region;
-      use FS::rate_prefix;
-      use FS::payment_gateway;
-      use FS::agent_payment_gateway;
-      use FS::XMLRPC;
-      use FS::payby;
-      use FS::cdr;
-      use FS::inventory_class;
-      use FS::inventory_item;
-      use FS::pkg_category;
-      use FS::pkg_class;
-      use FS::access_user;
-      use FS::access_user_pref;
-      use FS::access_group;
-      use FS::access_usergroup;
-      use FS::access_groupagent;
-      use FS::access_right;
-      use FS::AccessRight;
-      use FS::svc_phone;
-      use FS::reason_type;
-      use FS::reason;
-      use FS::cust_main_note;
-      use FS::tax_class;
-      use FS::cust_tax_location;
-      use FS::part_pkg_taxproduct;
-      use FS::part_pkg_taxoverride;
-      use FS::part_pkg_taxrate;
-      use FS::tax_rate;
-
-      if ( %%%RT_ENABLED%%% ) {
-        eval '
-          use RT::Tickets;
-          use RT::Transactions;
-          use RT::Users;
-          use RT::CurrentUser;
-          use RT::Templates;
-          use RT::Queues;
-          use RT::ScripActions;
-          use RT::ScripConditions;
-          use RT::Scrips;
-          use RT::Groups;
-          use RT::GroupMembers;
-          use RT::CustomFields;
-          use RT::CustomFieldValues;
-          use RT::ObjectCustomFieldValues;
-
-          #blah.  manually updated from RT::Interface::Web::Handler
-          use RT::Interface::Web;
-          use MIME::Entity;
-          use Text::Wrapper;
-          use Time::ParseDate;
-          use Time::HiRes;
-          use HTML::Scrubber;
-
-          #blah.  not even in RT::Interface::Web::Handler, just in 
-          #html/NoAuth/css/dhandler and rt-test-dependencies.  ask for it here
-          #to throw a real error instead of just a mysterious unstyled RT
-          use CSS::Squish 0.06;
-
-          #slow, unreliable, segfaults and is optional
-          #see rt/html/Ticket/Elements/ShowTransactionAttachments
-          #use Text::Quoted;
-
-          #?#use File::Path qw( rmtree );
-          #?#use File::Glob qw( bsd_glob );
-          #?#use File::Spec::Unix;
-
-        ';
-        die $@ if $@;
-      }
-
-      *CGI::redirect = sub {
-        my $self = shift;
-        my $cookie = '';
-        if ( $_[0] eq '-cookie' ) { #this isn't actually used at the moment
-          (my $x, $cookie) = (shift, shift);
-          $HTML::Mason::r->err_headers_out->add( 'Set-cookie' => $cookie );
-        }
-        my $location = shift;
-
-        use vars qw($m);
-
-        # false laziness w/below
-        if ( defined(@DBIx::Profile::ISA) ) { #profiling redirect
-
-          my $page =
-            qq!<HTML><BODY>Redirect to <A HREF="$location">$location</A>!.
-            '<BR><BR><PRE>'.
-              ( UNIVERSAL::can(dbh, 'sprintProfile')
-                  ? encode_entities(dbh->sprintProfile())
-                  : 'DBIx::Profile missing sprintProfile method;'.
-                    'unpatched or too old?'                        ).
-            #"\n\n". &sprintAutoProfile().  '</PRE>'.
-            "\n\n".                         '</PRE>'.
-            '</BODY></HTML>';
-          dbh->{'private_profile'} = {};
-          return $page;
-
-        } else { #normal redirect
-
-          $m->redirect($location);
-          '';
-
-        }
-
-      };
-      
-      if ( $HTML::Mason::r->filename !~ /\/rt\/.*NoAuth/ ) { #not RT images/JS
-
-        $cgi = new CGI;
-        &cgisuidsetup($cgi);
-        #&cgisuidsetup($r);
-        $p = popurl(2);
-        $fsurl = rooturl();
-
-      } elsif ( $HTML::Mason::r->filename =~ /\/rt\/REST\/.*NoAuth/ ) {
-
-        #need to log somebody in for the mail gw
-
-        ##old installs w/fs_selfs or selfserv??
-        #&adminsuidsetup('fs_selfservice');
-
-        &adminsuidsetup('fs_queue');
-
-      }
-
-      sub include {
-        use vars qw($m);
-        $m->scomp(@_);
-      }
-
-      sub errorpage {
-        use vars qw($m);
-        $m->comp('/elements/errorpage.html', @_);
-      }
-
-      sub redirect {
-        my( $location ) = @_;
-        use vars qw($m);
-        $m->clear_buffer;
-        #false laziness w/above
-        if ( defined(@DBIx::Profile::ISA) ) { #profiling redirect
-
-          $m->print(
-            qq!<HTML><BODY>Redirect to <A HREF="$location">$location</A>!.
-            '<BR><BR><PRE>'.
-              ( UNIVERSAL::can(dbh, 'sprintProfile')
-                  ? encode_entities(dbh->sprintProfile())
-                  : 'DBIx::Profile missing sprintProfile method;'.
-                    'unpatched or too old?'                        ).
-            #"\n\n". &sprintAutoProfile().  '</PRE>'.
-            "\n\n".                         '</PRE>'.
-            '</BODY></HTML>'
-          );
-          dbh->{'private_profile'} = {};
-
-          #whew.  removing this is all that's needed to fix the annoying
-          #blank-page-instead-of-profiling-redirect-when-called-from-an-include
-          #bug triggered by mason 1.32
-          #my $rv = $m->abort(200);
-
-        } else { #normal redirect
-
-          $m->redirect($location);
-
-        }
-
-      }
-
-    } # end package HTML::Mason::Commands;
-
     ###Module::Refresh->refresh;###
 
     $r->content_type('text/html');



More information about the freeside-commits mailing list