X-Git-Url: http://wagnertech.de/git?a=blobdiff_plain;f=SL%2FRP.pm;h=479d850308a5b541262c4304623125fa05cc27e9;hb=1fbcd0db6ef59f966caca6e5ba9e9d2bd58a06a5;hp=5554916c4d784e80274bab2fc1c19c32d44620a1;hpb=fc1e397330501fecd1ea62511c0965f0a5ef27b6;p=kivitendo-erp.git diff --git a/SL/RP.pm b/SL/RP.pm index 5554916c4..479d85030 100644 --- a/SL/RP.pm +++ b/SL/RP.pm @@ -25,7 +25,8 @@ # GNU General Public License for more details. # You should have received a copy of the GNU General Public License # along with this program; if not, write to the Free Software -# Foundation, Inc., 675 Mass Ave, Cambridge, MA 02139, USA. +# Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, +# MA 02110-1335, USA. #====================================================================== # # backend code for reports @@ -38,6 +39,7 @@ use SL::DBUtils; use Data::Dumper; use SL::DB::Helper::AccountingPeriod qw(get_balance_starting_date); use List::Util qw(sum); +use SL::DB; # use warnings; use strict; @@ -660,7 +662,7 @@ sub trial_balance { my ($self, $myconfig, $form, %options) = @_; - my $dbh = $form->dbconnect($myconfig); + my $dbh = SL::DB->client->dbh; my ($query, $sth, $ref); my %balance = (); @@ -1162,8 +1164,6 @@ sub trial_balance { } - $dbh->disconnect; - # debits and credits for headings foreach my $accno (@headingaccounts) { foreach $ref (@{ $form->{TB} }) { @@ -1200,7 +1200,7 @@ sub aging { my ($self, $myconfig, $form) = @_; # connect to database - my $dbh = $form->dbconnect($myconfig); + my $dbh = SL::DB->client->dbh; my ($invoice, $arap, $buysell, $ct, $ct_id, $ml); @@ -1332,9 +1332,6 @@ sub aging { $sth->finish; - # disconnect - $dbh->disconnect; - $main::lxdebug->leave_sub(); } @@ -1343,8 +1340,7 @@ sub get_customer { my ($self, $myconfig, $form) = @_; - # connect to database - my $dbh = $form->dbconnect($myconfig); + my $dbh = SL::DB->client->dbh; my $ct = $form->{ct} eq "customer" ? "customer" : "vendor"; @@ -1354,7 +1350,6 @@ sub get_customer { WHERE ct.id = ?|; ($form->{ $form->{ct} }, $form->{email}, $form->{cc}, $form->{bcc}) = selectrow_query($form, $dbh, $query, $form->{"${ct}_id"}); - $dbh->disconnect; $main::lxdebug->leave_sub(); } @@ -1364,8 +1359,7 @@ sub tax_report { my ($self, $myconfig, $form) = @_; - # connect to database - my $dbh = $form->dbconnect($myconfig); + my $dbh = SL::DB->client->dbh; my ($null, $department_id) = split /--/, $form->{department}; @@ -1454,8 +1448,6 @@ sub tax_report { $form->{TR} = selectall_hashref_query($form, $dbh, $query); - $dbh->disconnect; - $main::lxdebug->leave_sub(); } @@ -1465,7 +1457,7 @@ sub paymentaccounts { my ($self, $myconfig, $form) = @_; # connect to database, turn AutoCommit off - my $dbh = $form->dbconnect_noauto($myconfig); + my $dbh = SL::DB->client->dbh; my $ARAP = $form->{db} eq "ar" ? "AR" : "AP"; @@ -1476,8 +1468,6 @@ sub paymentaccounts { WHERE link LIKE '%${ARAP}_paid%'|; $form->{PR} = selectall_hashref_query($form, $dbh, $query); - $dbh->disconnect; - $main::lxdebug->leave_sub(); } @@ -1487,7 +1477,7 @@ sub payments { my ($self, $myconfig, $form) = @_; # connect to database, turn AutoCommit off - my $dbh = $form->dbconnect_noauto($myconfig); + my $dbh = SL::DB->client->dbh; my $ml = 1; my $arap; @@ -1608,8 +1598,6 @@ sub payments { $sth_details->finish(); } - $dbh->disconnect; - $main::lxdebug->leave_sub(); } @@ -1618,8 +1606,7 @@ sub bwa { my ($self, $myconfig, $form) = @_; - # connect to database - my $dbh = $form->dbconnect($myconfig); + my $dbh = SL::DB->client->dbh; my $last_period = 0; my $category; @@ -1819,7 +1806,6 @@ sub bwa { } } - $dbh->disconnect; $main::lxdebug->leave_sub(); } @@ -1873,12 +1859,8 @@ sub erfolgsrechnung { my ($self, $myconfig, $form) = @_; $form->{company} = $::instance_conf->get_company; $form->{address} = $::instance_conf->get_address; - #injection-filter - $form->{fromdate} =~ s/[^0-9\.]//g; - $form->{todate} =~ s/[^0-9\.]//g; - #input validation - $form->{fromdate} = "01.01.2000" if $form->{fromdate} !~ m/[0-9]*\.[0-9]*\.[0-9]*/; - $form->{todate} = $form->current_date(%{$myconfig}) if $form->{todate} !~ m/[0-9]*\.[0-9]*\.[0-9]*/; + $form->{fromdate} = DateTime->new(year => 2000, month => 1, day => 1)->to_kivitendo unless $form->{fromdate}; + $form->{todate} = $form->current_date(%{$myconfig}) unless $form->{todate}; my %categories = (I => "ERTRAG", E => "AUFWAND"); my $fromdate = conv_dateq($form->{fromdate}); @@ -1914,9 +1896,9 @@ sub get_accounts_ch { my ($inclusion); if ($category eq 'I') { - $inclusion = "AND pos_er = NULL OR pos_er > '0' AND pos_er <= '5'"; + $inclusion = "AND pos_er = NULL OR pos_er = '1'"; } elsif ($category eq 'E') { - $inclusion = "AND pos_er = NULL OR pos_er >= '6' AND pos_er < '100'"; + $inclusion = "AND pos_er = NULL OR pos_er = '6'"; } else { $inclusion = ""; } @@ -1924,10 +1906,10 @@ sub get_accounts_ch { my $query = qq| SELECT id, accno, description, category FROM chart - WHERE category = '$category' $inclusion + WHERE category = ? $inclusion ORDER BY accno |; - my $accounts = _query($query); + my $accounts = _query($query, $category); $main::lxdebug->leave_sub(); return $accounts; @@ -1941,11 +1923,11 @@ sub get_total_ch { my $query = qq| SELECT SUM(amount) FROM acc_trans - WHERE chart_id = '$chart_id' - AND transdate >= $fromdate - AND transdate <= $todate + WHERE chart_id = ? + AND transdate >= ? + AND transdate <= ? |; - $total += _query($query)->[0]->{sum}; + $total += _query($query, $chart_id, $fromdate, $todate)->[0]->{sum}; $main::lxdebug->leave_sub(); return $total;