-my $limit = '';
-$limit .= "LIMIT $maxrecords" if $maxrecords;
-
-my $offset = $cgi->param('offset') || 0;
-$limit .= " OFFSET $offset" if $offset;
-
-my $total;
-
-my($query) = $cgi->keywords;
-my $sortby;
-my @cust_pkg;
-
-if ( $cgi->param('magic') && $cgi->param('magic') eq 'bill' ) {
- $sortby=\*bill_sort;
-
- #false laziness with cust_pay.cgi
- my $range = '';
- if ( $cgi->param('beginning')
- && $cgi->param('beginning') =~ /^([ 0-9\-\/]{0,10})$/ ) {
- my $beginning = str2time($1);
- $range = " WHERE bill >= $beginning ";
- }
- if ( $cgi->param('ending')
- && $cgi->param('ending') =~ /^([ 0-9\-\/]{0,10})$/ ) {
- my $ending = str2time($1) + 86400;
- $range .= ( $range ? ' AND ' : ' WHERE ' ). " bill <= $ending ";
- }
-
- $range .= ( $range ? 'AND ' : ' WHERE ' ). '( cancel IS NULL OR cancel = 0 )';
-
- #false laziness with below
- my $statement = "SELECT COUNT(*) FROM cust_pkg $range";
- warn $statement;
- my $sth = dbh->prepare($statement) or die dbh->errstr." preparing $statement";
- $sth->execute or die "Error executing \"$statement\": ". $sth->errstr;
-
- $total = $sth->fetchrow_arrayref->[0];
-
- @cust_pkg = qsearch('cust_pkg',{}, '', " $range ORDER BY bill $limit" );
-
-} else {
-
- my $qual = '';
- if ( $cgi->param('magic') &&
- $cgi->param('magic') =~ /^(active|suspended|canceled)$/
- ) {
-
- if ( $cgi->param('magic') eq 'active' ) {
- $qual = 'WHERE ( susp IS NULL OR susp = 0 )'.
- ' AND ( cancel IS NULL OR cancel = 0)';
- } elsif ( $cgi->param('magic') eq 'suspended' ) {
- $qual = 'WHERE susp IS NOT NULL AND susp > 0'.
- ' AND ( cancel IS NULL OR cancel = 0)';
- } elsif ( $cgi->param('magic') eq 'canceled' ) {
- $qual = 'WHERE cancel IS NOT NULL AND cancel > 0';
- } else {
- die "guru meditation #420";
- }
-
- $sortby = \*pkgnum_sort;
-
- if ( $cgi->param('pkgpart') =~ /^(\d+)$/ ) {
- $qual .= " AND pkgpart = $1";
- }
-
- } elsif ( $query eq 'pkgnum' ) {
-
- $sortby=\*pkgnum_sort;
-
- } elsif ( $query eq 'SUSP_pkgnum' ) {
-
- $sortby=\*pkgnum_sort;
-
- $qual = 'WHERE susp IS NOT NULL AND susp != 0';
-
- } elsif ( $query eq 'APKG_pkgnum' ) {
-
- $sortby=\*pkgnum_sort;
-
- #@cust_pkg=();
- ##perhaps this should go in cust_pkg as a qsearch-like constructor?
- #my($cust_pkg);
- #foreach $cust_pkg (
- # qsearch('cust_pkg',{}, '', "ORDER BY pkgnum $limit" )
- #) {
- # my($flag)=0;
- # my($pkg_svc);
- # PKG_SVC:
- # foreach $pkg_svc (qsearch('pkg_svc',{ 'pkgpart' => $cust_pkg->pkgpart })) {
- # if ( $pkg_svc->quantity
- # > scalar(qsearch('cust_svc',{
- # 'pkgnum' => $cust_pkg->pkgnum,
- # 'svcpart' => $pkg_svc->svcpart,
- # }))
- # )
- # {
- # $flag=1;
- # last PKG_SVC;
- # }
- # }
- # push @cust_pkg, $cust_pkg if $flag;
- #}
-
- if ( driver_name eq 'mysql' ) {
- #$query = "DROP TABLE temp1_$$,temp2_$$;";
- #my $sth = dbh->prepare($query);
- #$sth->execute;
-
- $query = "CREATE TEMPORARY TABLE temp1_$$ TYPE=MYISAM
- SELECT cust_svc.pkgnum,cust_svc.svcpart,COUNT(*) as count
- FROM cust_pkg,cust_svc,pkg_svc
- WHERE cust_pkg.pkgnum = cust_svc.pkgnum
- AND cust_svc.svcpart = pkg_svc.svcpart
- AND cust_pkg.pkgpart = pkg_svc.pkgpart
- GROUP BY cust_svc.pkgnum,cust_svc.svcpart";
- my $sth = dbh->prepare($query) or die dbh->errstr. " preparing $query";
-
- $sth->execute or die "Error executing \"$query\": ". $sth->errstr;