[freeside-commits] freeside/httemplate/search cust_bill_pkg.cgi, 1.7, 1.8
Ivan,,,
ivan at wavetail.420.am
Sat May 31 20:19:09 PDT 2008
Update of /home/cvs/cvsroot/freeside/httemplate/search
In directory wavetail.420.am:/tmp/cvs-serv3681
Modified Files:
cust_bill_pkg.cgi
Log Message:
fix line item report for agent-virtualized packages, clean up sloppy $where stringification, hard agent virtualization
Index: cust_bill_pkg.cgi
===================================================================
RCS file: /home/cvs/cvsroot/freeside/httemplate/search/cust_bill_pkg.cgi,v
retrieving revision 1.7
retrieving revision 1.8
diff -u -d -r1.7 -r1.8
--- cust_bill_pkg.cgi 3 Feb 2007 11:36:30 -0000 1.7
+++ cust_bill_pkg.cgi 1 Jun 2008 03:19:06 -0000 1.8
@@ -64,39 +64,35 @@
die "access denied"
unless $FS::CurrentUser::CurrentUser->access_right('Financial reports');
-my($beginning, $ending) = FS::UI::Web::parse_beginning_ending($cgi);
-
-my $join_cust = "
- JOIN cust_bill USING ( invnum )
- LEFT JOIN cust_main USING ( custnum )
-";
+#here is the agent virtualization
+my $agentnums_sql =
+ $FS::CurrentUser::CurrentUser->agentnums_sql( 'table' => 'cust_main' );
-my $join_pkg = "
- LEFT JOIN cust_pkg USING ( pkgnum )
- LEFT JOIN part_pkg USING ( pkgpart )
-";
+my @where = ( $agentnums_sql );
-my $where = " WHERE _date >= $beginning AND _date <= $ending ";
+my($beginning, $ending) = FS::UI::Web::parse_beginning_ending($cgi);
+push @where, "_date >= $beginning",
+ "_date <= $ending";
-$where .= " AND payby != 'COMP' "
+push @where , " payby != 'COMP' "
unless $cgi->param('include_comp_cust');
if ( $cgi->param('agentnum') =~ /^(\d+)$/ ) {
- $where .= " AND agentnum = $1 ";
+ push @where, "cust_main.agentnum = $1";
}
if ( $cgi->param('classnum') =~ /^(\d+)$/ ) {
if ( $1 == 0 ) {
- $where .= " AND classnum IS NULL ";
+ push @where, "classnum IS NULL";
} else {
- $where .= " AND classnum = $1 ";
+ push @where, "classnum = $1";
}
}
if ( $cgi->param('out') ) {
- $where .= "
- AND 0 = (
+ push @where, "
+ 0 = (
SELECT COUNT(*) FROM cust_main_county
WHERE ( cust_main_county.county = cust_main.county
OR ( cust_main_county.county IS NULL AND cust_main.county = '' )
@@ -118,21 +114,20 @@
my $county = dbh->quote( $cgi->param('county') );
my $state = dbh->quote( $cgi->param('state') );
my $country = dbh->quote( $cgi->param('country') );
- $where .= "
- AND ( county = $county OR $county = '' )
- AND ( state = $state OR $state = '' )
- AND country = $country
- ";
- $where .= ' AND taxclass = '. dbh->quote( $cgi->param('taxclass') )
+ push @where,
+ " ( county = $county OR $county = '' ) ",
+ " ( state = $state OR $state = '' ) ",
+ " country = $country "
+ ;
+ push @where, ' taxclass = '. dbh->quote( $cgi->param('taxclass') )
if $cgi->param('taxclass');
}
-$where .= ' AND pkgnum != 0' if $cgi->param('nottax');
-
-$where .= ' AND pkgnum = 0' if $cgi->param('istax');
+push @where, 'pkgnum != 0' if $cgi->param('nottax');
+push @where, 'pkgnum = 0' if $cgi->param('istax');
-$where .= " AND tax = 'Y'" if $cgi->param('cust_tax');
+push @where, " tax = 'Y' " if $cgi->param('cust_tax');
my $count_query;
if ( $cgi->param('pkg_tax') ) {
@@ -153,12 +148,9 @@
)
";
- $where .= " AND (
- ( part_pkg.setuptax = 'Y' AND cust_bill_pkg.setup > 0 )
- OR ( part_pkg.recurtax = 'Y' AND cust_bill_pkg.recur > 0 )
- )
- AND ( tax != 'Y' OR tax IS NULL )
- ";
+ push @where, "( ( part_pkg.setuptax = 'Y' AND cust_bill_pkg.setup > 0 )
+ OR ( part_pkg.recurtax = 'Y' AND cust_bill_pkg.recur > 0 ) )",
+ "( tax != 'Y' OR tax IS NULL )";
} else {
@@ -166,7 +158,20 @@
"SELECT COUNT(*), SUM(cust_bill_pkg.setup + cust_bill_pkg.recur)";
}
-$count_query .= " FROM cust_bill_pkg $join_cust $join_pkg $where";
+
+my $where = ' WHERE '. join(' AND ', @where);
+
+my $join_cust = "
+ JOIN cust_bill USING ( invnum )
+ LEFT JOIN cust_main USING ( custnum )
+";
+
+my $join_pkg = "
+ LEFT JOIN cust_pkg USING ( pkgnum )
+ LEFT JOIN part_pkg USING ( pkgpart )
+";
+
+$count_query .= " FROM cust_bill_pkg $join_cust $join_pkg $where";
my $query = {
'table' => 'cust_bill_pkg',
More information about the freeside-commits
mailing list