X-Git-Url: http://wagnertech.de/git?a=blobdiff_plain;f=SL%2FAM.pm;h=7818fb18e3f71346c77983fec70cf5b7b0b91eb6;hb=187095913ed459f19363ede1c46a1de91f60e8c8;hp=896b3c84bc965220623bdb835b08bc0bc9243f78;hpb=e5e96630943eecefe1090cf39f600850e8f9e291;p=kivitendo-erp.git diff --git a/SL/AM.pm b/SL/AM.pm index 896b3c84b..7818fb18e 100644 --- a/SL/AM.pm +++ b/SL/AM.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. #====================================================================== # # Administration module @@ -46,6 +47,7 @@ use SL::DB::AuthUser; use SL::DB::Default; use SL::DB::Employee; use SL::DB::Chart; +use SL::DB; use SL::GenericTranslations; use strict; @@ -107,7 +109,7 @@ sub get_account { startdate => $taxkey->startdate->to_kivitendo, taxdescription => $taxkey->tax->taxdescription, rate => $taxkey->tax->rate, - accno => $chart_obj->accno, + accno => defined $taxkey->tax->chart_id ? $taxkey->tax->chart->accno : undef, }; } @@ -122,15 +124,22 @@ sub get_account { } sub save_account { + my ($self, $myconfig, $form) = @_; $main::lxdebug->enter_sub(); + my $rc = SL::DB->client->with_transaction(\&_save_account, $self, $myconfig, $form); + + $::lxdebug->leave_sub; + return $rc; +} + +sub _save_account { # TODO: it should be forbidden to change an account to a heading if there # have been bookings to this account in the past my ($self, $myconfig, $form) = @_; - # connect to database, turn off AutoCommit - my $dbh = $form->dbconnect_noauto($myconfig); + my $dbh = SL::DB->client->dbh; for (qw(AR_include_in_dropdown AP_include_in_dropdown summary_account)) { $form->{$form->{$_}} = $form->{$_} if $form->{$_}; @@ -143,23 +152,15 @@ sub save_account { } } - $form->{link} = ""; - foreach my $item ($form->{AR}, $form->{AR_amount}, - $form->{AR_tax}, $form->{AR_paid}, - $form->{AP}, $form->{AP_amount}, - $form->{AP_tax}, $form->{AP_paid}, - $form->{IC}, $form->{IC_sale}, - $form->{IC_cogs}, $form->{IC_taxpart}, - $form->{IC_income}, $form->{IC_expense}, - $form->{IC_taxservice} - ) { - $form->{link} .= "${item}:" if ($item); - } - chop $form->{link}; + my @link_order = qw(AR AR_amount AR_tax AR_paid AP AP_amount AP_tax AP_paid IC IC_sale IC_cogs IC_taxpart IC_income IC_expense IC_taxservice); + $form->{link} = join ':', grep $_, map $form->{$_}, @link_order; # strip blanks from accno map { $form->{$_} =~ s/ //g; } qw(accno); + # collapse multiple (horizontal) whitespace in chart description (Ticket 148) + map { $form->{$_} =~ s/\h+/ /g } qw(description); + my ($query, $sth); if ($form->{id} eq "NULL") { @@ -364,42 +365,32 @@ SQL do_query($form, $dbh, $query, $form->{id}); - # commit - my $rc = $dbh->commit; - $dbh->disconnect; - - $main::lxdebug->leave_sub(); - - return $rc; + return 1; } sub delete_account { + my ($self, $myconfig, $form) = @_; $main::lxdebug->enter_sub(); + my $rc = SL::DB->client->with_transaction(\&_delete_account, $self, $myconfig, $form); + + $::lxdebug->leave_sub; + return $rc; +} + +sub _delete_account { my ($self, $myconfig, $form) = @_; - # connect to database, turn off AutoCommit - my $dbh = $form->dbconnect_noauto($myconfig); + my $dbh = SL::DB->client->dbh; my $query = qq|SELECT count(*) FROM acc_trans a WHERE a.chart_id = ?|; my ($count) = selectrow_query($form, $dbh, $query, $form->{id}); if ($count) { - $dbh->disconnect; - $main::lxdebug->leave_sub(); return; } - # set inventory_accno_id, income_accno_id, expense_accno_id to defaults - foreach my $type (qw(inventory income expense)) { - $query = - qq|UPDATE parts | . - qq|SET ${type}_accno_id = (SELECT ${type}_accno_id FROM defaults) | . - qq|WHERE ${type}_accno_id = ?|; - do_query($form, $dbh, $query, $form->{id}); - } - $query = qq|DELETE FROM tax WHERE chart_id = ?|; do_query($form, $dbh, $query, $form->{id}); @@ -416,13 +407,7 @@ sub delete_account { WHERE id = ?|; do_query($form, $dbh, $query, $form->{id}); - # commit and redirect - my $rc = $dbh->commit; - $dbh->disconnect; - - $main::lxdebug->leave_sub(); - - return $rc; + return 1; } sub lead { @@ -430,8 +415,7 @@ sub lead { my ($self, $myconfig, $form) = @_; - # connect to database - my $dbh = $form->dbconnect($myconfig); + my $dbh = SL::DB->client->dbh; my $query = qq|SELECT id, lead FROM leads @@ -445,7 +429,6 @@ sub lead { } $sth->finish; - $dbh->disconnect; $main::lxdebug->leave_sub(); } @@ -455,8 +438,7 @@ sub get_lead { my ($self, $myconfig, $form) = @_; - # connect to database - my $dbh = $form->dbconnect($myconfig); + my $dbh = SL::DB->client->dbh; my $query = qq|SELECT l.id, l.lead | . @@ -471,8 +453,6 @@ sub get_lead { $sth->finish; - $dbh->disconnect; - $main::lxdebug->leave_sub(); } @@ -482,8 +462,7 @@ sub save_lead { my ($self, $myconfig, $form) = @_; my ($query); - # connect to database - my $dbh = $form->dbconnect($myconfig); + my $dbh = SL::DB->client->dbh; my @values = ($form->{description}); # id is the old record @@ -499,8 +478,6 @@ sub save_lead { } do_query($form, $dbh, $query, @values); - $dbh->disconnect; - $main::lxdebug->leave_sub(); } @@ -510,14 +487,11 @@ sub delete_lead { my ($self, $myconfig, $form) = @_; my ($query); - # connect to database - my $dbh = $form->dbconnect($myconfig); - - $query = qq|DELETE FROM leads - WHERE id = ?|; - do_query($form, $dbh, $query, $form->{id}); - - $dbh->disconnect; + SL::DB->client->with_transaction(sub { + $query = qq|DELETE FROM leads WHERE id = ?|; + do_query($form, SL::DB->client->dbh, $query, $form->{id}); + 1; + }) or do { die SL::DB->client->error }; $main::lxdebug->leave_sub(); } @@ -527,8 +501,7 @@ sub language { my ($self, $myconfig, $form, $return_list) = @_; - # connect to database - my $dbh = $form->dbconnect($myconfig); + my $dbh = SL::DB->client->dbh; my $query = "SELECT id, description, template_code, article_code, " . @@ -545,7 +518,6 @@ sub language { } $sth->finish; - $dbh->disconnect; $main::lxdebug->leave_sub(); @@ -561,8 +533,7 @@ sub get_language { my ($self, $myconfig, $form) = @_; - # connect to database - my $dbh = $form->dbconnect($myconfig); + my $dbh = SL::DB->client->dbh; my $query = "SELECT description, template_code, article_code, " . @@ -577,8 +548,6 @@ sub get_language { $sth->finish; - $dbh->disconnect; - $main::lxdebug->leave_sub(); } @@ -587,15 +556,13 @@ sub get_language_details { my ($self, $myconfig, $form, $id) = @_; - # connect to database - my $dbh = $form->dbconnect($myconfig); + my $dbh = SL::DB->client->dbh; my $query = "SELECT template_code, " . " output_numberformat, output_dateformat, output_longdates " . "FROM language WHERE id = ?"; my @res = selectrow_query($form, $dbh, $query, $id); - $dbh->disconnect; $main::lxdebug->leave_sub(); @@ -607,33 +574,33 @@ sub save_language { my ($self, $myconfig, $form) = @_; - # connect to database - my $dbh = $form->dbconnect($myconfig); - my (@values, $query); - - map({ push(@values, $form->{$_}); } - qw(description template_code article_code - output_numberformat output_dateformat output_longdates)); - - # id is the old record - if ($form->{id}) { - $query = - "UPDATE language SET " . - " description = ?, template_code = ?, article_code = ?, " . - " output_numberformat = ?, output_dateformat = ?, " . - " output_longdates = ? " . - "WHERE id = ?"; - push(@values, $form->{id}); - } else { - $query = - "INSERT INTO language (" . - " description, template_code, article_code, " . - " output_numberformat, output_dateformat, output_longdates" . - ") VALUES (?, ?, ?, ?, ?, ?)"; - } - do_query($form, $dbh, $query, @values); - - $dbh->disconnect; + SL::DB->client->with_transaction(sub { + my $dbh = SL::DB->client->dbh; + my (@values, $query); + + map({ push(@values, $form->{$_}); } + qw(description template_code article_code + output_numberformat output_dateformat output_longdates)); + + # id is the old record + if ($form->{id}) { + $query = + "UPDATE language SET " . + " description = ?, template_code = ?, article_code = ?, " . + " output_numberformat = ?, output_dateformat = ?, " . + " output_longdates = ? " . + "WHERE id = ?"; + push(@values, $form->{id}); + } else { + $query = + "INSERT INTO language (" . + " description, template_code, article_code, " . + " output_numberformat, output_dateformat, output_longdates" . + ") VALUES (?, ?, ?, ?, ?, ?)"; + } + do_query($form, $dbh, $query, @values); + 1; + }) or do { die SL::DB->client->error }; $main::lxdebug->leave_sub(); } @@ -644,19 +611,18 @@ sub delete_language { my ($self, $myconfig, $form) = @_; my $query; - # connect to database - my $dbh = $form->dbconnect_noauto($myconfig); + SL::DB->client->with_transaction(sub { + my $dbh = SL::DB->client->dbh; - foreach my $table (qw(generic_translations units_language)) { - $query = qq|DELETE FROM $table WHERE language_id = ?|; - do_query($form, $dbh, $query, $form->{"id"}); - } - - $query = "DELETE FROM language WHERE id = ?"; - do_query($form, $dbh, $query, $form->{"id"}); + foreach my $table (qw(generic_translations units_language)) { + $query = qq|DELETE FROM $table WHERE language_id = ?|; + do_query($form, $dbh, $query, $form->{"id"}); + } - $dbh->commit(); - $dbh->disconnect; + $query = "DELETE FROM language WHERE id = ?"; + do_query($form, $dbh, $query, $form->{"id"}); + 1; + }) or do { die SL::DB->client->error }; $main::lxdebug->leave_sub(); } @@ -775,7 +741,7 @@ sub get_defaults { my $myconfig = \%main::myconfig; my $form = $main::form; - my $dbh = $params{dbh} || $form->get_standard_dbh($myconfig); + my $dbh = $params{dbh} || SL::DB->client->dbh; my $defaults = selectfirst_hashref_query($form, $dbh, qq|SELECT * FROM defaults|) || {}; @@ -791,7 +757,7 @@ sub closedto { my ($self, $myconfig, $form) = @_; - my $dbh = $form->dbconnect($myconfig); + my $dbh = SL::DB->client->dbh; my $query = qq|SELECT closedto, max_future_booking_interval, revtrans FROM defaults|; my $sth = $dbh->prepare($query); @@ -801,8 +767,6 @@ sub closedto { $sth->finish; - $dbh->disconnect; - $main::lxdebug->leave_sub(); } @@ -811,23 +775,24 @@ sub closebooks { my ($self, $myconfig, $form) = @_; - my $dbh = $form->dbconnect($myconfig); + SL::DB->client->with_transaction(sub { + my $dbh = SL::DB->client->dbh; - my ($query, @values); + my ($query, @values); - # is currently NEVER trueish (no more hidden revtrans in $form) - # if ($form->{revtrans}) { - # $query = qq|UPDATE defaults SET closedto = NULL, revtrans = '1'|; - # -> therefore you can only set this to false (which is already the default) - # and this flag is currently only checked in gl.pl. TOOD Can probably be removed + # is currently NEVER trueish (no more hidden revtrans in $form) + # if ($form->{revtrans}) { + # $query = qq|UPDATE defaults SET closedto = NULL, revtrans = '1'|; + # -> therefore you can only set this to false (which is already the default) + # and this flag is currently only checked in gl.pl. TOOD Can probably be removed - $query = qq|UPDATE defaults SET closedto = ?, max_future_booking_interval = ?, revtrans = '0'|; - @values = (conv_date($form->{closedto}), conv_i($form->{max_future_booking_interval})); - - # set close in defaults - do_query($form, $dbh, $query, @values); + $query = qq|UPDATE defaults SET closedto = ?, max_future_booking_interval = ?, revtrans = '0'|; + @values = (conv_date($form->{closedto}), conv_i($form->{max_future_booking_interval})); - $dbh->disconnect; + # set close in defaults + do_query($form, $dbh, $query, @values); + 1; + }) or do { die SL::DB->client->error }; $main::lxdebug->leave_sub(); } @@ -853,7 +818,7 @@ sub retrieve_units { my ($self, $myconfig, $form, $prefix) = @_; $prefix ||= ''; - my $dbh = $form->get_standard_dbh; + my $dbh = SL::DB->client->dbh; my $query = "SELECT *, base_unit AS original_base_unit FROM units"; @@ -942,7 +907,7 @@ sub units_in_use { my ($self, $myconfig, $form, $units) = @_; - my $dbh = $form->dbconnect($myconfig); + my $dbh = SL::DB->client->dbh; map({ $_->{"in_use"} = 0; } values(%{$units})); @@ -979,8 +944,6 @@ sub units_in_use { } } - $dbh->disconnect(); - $main::lxdebug->leave_sub(); } @@ -1111,37 +1074,45 @@ sub add_unit { my ($self, $myconfig, $form, $name, $base_unit, $factor, $languages) = @_; - my $dbh = $form->dbconnect_noauto($myconfig); + SL::DB->client->with_transaction(sub { + my $dbh = SL::DB->client->dbh; - my $query = qq|SELECT COALESCE(MAX(sortkey), 0) + 1 FROM units|; - my ($sortkey) = selectrow_query($form, $dbh, $query); + my $query = qq|SELECT COALESCE(MAX(sortkey), 0) + 1 FROM units|; + my ($sortkey) = selectrow_query($form, $dbh, $query); - $query = "INSERT INTO units (name, base_unit, factor, sortkey) " . - "VALUES (?, ?, ?, ?)"; - do_query($form, $dbh, $query, $name, $base_unit, $factor, $sortkey); + $query = "INSERT INTO units (name, base_unit, factor, sortkey) " . + "VALUES (?, ?, ?, ?)"; + do_query($form, $dbh, $query, $name, $base_unit, $factor, $sortkey); - if ($languages) { - $query = "INSERT INTO units_language (unit, language_id, localized, localized_plural) VALUES (?, ?, ?, ?)"; - my $sth = $dbh->prepare($query); - foreach my $lang (@{$languages}) { - my @values = ($name, $lang->{"id"}, $lang->{"localized"}, $lang->{"localized_plural"}); - $sth->execute(@values) || $form->dberror($query . " (" . join(", ", @values) . ")"); + if ($languages) { + $query = "INSERT INTO units_language (unit, language_id, localized, localized_plural) VALUES (?, ?, ?, ?)"; + my $sth = $dbh->prepare($query); + foreach my $lang (@{$languages}) { + my @values = ($name, $lang->{"id"}, $lang->{"localized"}, $lang->{"localized_plural"}); + $sth->execute(@values) || $form->dberror($query . " (" . join(", ", @values) . ")"); + } + $sth->finish(); } - $sth->finish(); - } - - $dbh->commit(); - $dbh->disconnect(); + 1; + }) or do { die SL::DB->client->error }; $main::lxdebug->leave_sub(); } sub save_units { + my ($self, $myconfig, $form, $units, $delete_units) = @_; $main::lxdebug->enter_sub(); + my $rc = SL::DB->client->with_transaction(\&_save_units, $self, $myconfig, $form, $units, $delete_units); + + $::lxdebug->leave_sub; + return $rc; +} + +sub _save_units { my ($self, $myconfig, $form, $units, $delete_units) = @_; - my $dbh = $form->dbconnect_noauto($myconfig); + my $dbh = SL::DB->client->dbh; my ($base_unit, $unit, $sth, $query); @@ -1188,10 +1159,8 @@ sub save_units { $sth->finish(); $sth_lang->finish(); - $dbh->commit(); - $dbh->disconnect(); - $main::lxdebug->leave_sub(); + return 1; } sub taxes { @@ -1199,8 +1168,7 @@ sub taxes { my ($self, $myconfig, $form) = @_; - # connect to database - my $dbh = $form->dbconnect($myconfig); + my $dbh = SL::DB->client->dbh; my $query = qq|SELECT t.id, @@ -1225,7 +1193,6 @@ sub taxes { } $sth->finish; - $dbh->disconnect; $main::lxdebug->leave_sub(); } @@ -1235,7 +1202,7 @@ sub get_tax_accounts { my ($self, $myconfig, $form) = @_; - my $dbh = $form->dbconnect($myconfig); + my $dbh = SL::DB->client->dbh; # get Accounts from chart my $query = qq{ SELECT @@ -1267,8 +1234,6 @@ sub get_tax_accounts { $sth->finish; - $dbh->disconnect; - $main::lxdebug->leave_sub(); } @@ -1277,8 +1242,7 @@ sub get_tax { my ($self, $myconfig, $form) = @_; - # connect to database - my $dbh = $form->dbconnect($myconfig); + my $dbh = SL::DB->client->dbh; my $query = qq|SELECT taxkey, @@ -1329,19 +1293,24 @@ sub get_tax { $sth->finish; } - $dbh->disconnect; - $main::lxdebug->leave_sub(); } sub save_tax { + my ($self, $myconfig, $form) = @_; $main::lxdebug->enter_sub(); + my $rc = SL::DB->client->with_transaction(\&_save_tax, $self, $myconfig, $form); + + $::lxdebug->leave_sub; + return $rc; +} + +sub _save_tax { my ($self, $myconfig, $form) = @_; my $query; - # connect to database - my $dbh = $form->get_standard_dbh($myconfig); + my $dbh = SL::DB->client->dbh; $form->{rate} = $form->{rate} / 100; @@ -1392,10 +1361,6 @@ sub save_tax { 'language_id' => $language_id, 'translation' => $form->{translations}->{$language_id}); } - - $dbh->commit(); - - $main::lxdebug->leave_sub(); } sub delete_tax { @@ -1404,14 +1369,11 @@ sub delete_tax { my ($self, $myconfig, $form) = @_; my $query; - # connect to database - my $dbh = $form->get_standard_dbh($myconfig); - - $query = qq|DELETE FROM tax - WHERE id = ?|; - do_query($form, $dbh, $query, $form->{id}); - - $dbh->commit(); + SL::DB->client->with_transaction(sub { + $query = qq|DELETE FROM tax WHERE id = ?|; + do_query($form, SL::DB->client->dbh, $query, $form->{id}); + 1; + }) or do { die SL::DB->client->error }; $main::lxdebug->leave_sub(); } @@ -1421,23 +1383,23 @@ sub save_price_factor { my ($self, $myconfig, $form) = @_; - # connect to database - my $dbh = $form->get_standard_dbh($myconfig); + SL::DB->client->with_transaction(sub { + my $dbh = SL::DB->client->dbh; - my $query; - my @values = ($form->{description}, conv_i($form->{factor})); + my $query; + my @values = ($form->{description}, conv_i($form->{factor})); - if ($form->{id}) { - $query = qq|UPDATE price_factors SET description = ?, factor = ? WHERE id = ?|; - push @values, conv_i($form->{id}); - - } else { - $query = qq|INSERT INTO price_factors (description, factor, sortkey) VALUES (?, ?, (SELECT COALESCE(MAX(sortkey), 0) + 1 FROM price_factors))|; - } + if ($form->{id}) { + $query = qq|UPDATE price_factors SET description = ?, factor = ? WHERE id = ?|; + push @values, conv_i($form->{id}); - do_query($form, $dbh, $query, @values); + } else { + $query = qq|INSERT INTO price_factors (description, factor, sortkey) VALUES (?, ?, (SELECT COALESCE(MAX(sortkey), 0) + 1 FROM price_factors))|; + } - $dbh->commit(); + do_query($form, $dbh, $query, @values); + 1; + }) or do { die SL::DB->client->error }; $main::lxdebug->leave_sub(); } @@ -1447,8 +1409,7 @@ sub get_all_price_factors { my ($self, $myconfig, $form) = @_; - # connect to database - my $dbh = $form->get_standard_dbh($myconfig); + my $dbh = SL::DB->client->dbh; $form->{PRICE_FACTORS} = selectall_hashref_query($form, $dbh, qq|SELECT * FROM price_factors ORDER BY sortkey|); @@ -1461,7 +1422,7 @@ sub get_price_factor { my ($self, $myconfig, $form) = @_; # connect to database - my $dbh = $form->get_standard_dbh($myconfig); + my $dbh = SL::DB->client->dbh; my $query = qq|SELECT description, factor, ((SELECT COUNT(*) FROM parts WHERE price_factor_id = ?) + @@ -1479,11 +1440,10 @@ sub delete_price_factor { my ($self, $myconfig, $form) = @_; - # connect to database - my $dbh = $form->get_standard_dbh($myconfig); - - do_query($form, $dbh, qq|DELETE FROM price_factors WHERE id = ?|, conv_i($form->{id})); - $dbh->commit(); + SL::DB->client->with_transaction(sub { + do_query($form, SL::DB->client->dbh, qq|DELETE FROM price_factors WHERE id = ?|, conv_i($form->{id})); + 1; + }) or do { die SL::DB->client->error }; $main::lxdebug->leave_sub(); } @@ -1493,35 +1453,35 @@ sub save_warehouse { my ($self, $myconfig, $form) = @_; - # connect to database - my $dbh = $form->get_standard_dbh($myconfig); + SL::DB->client->with_transaction(sub { + my $dbh = SL::DB->client->dbh; - my ($query, @values, $sth); + my ($query, @values, $sth); - if (!$form->{id}) { - $query = qq|SELECT nextval('id')|; - ($form->{id}) = selectrow_query($form, $dbh, $query); - - $query = qq|INSERT INTO warehouse (id, sortkey) VALUES (?, (SELECT COALESCE(MAX(sortkey), 0) + 1 FROM warehouse))|; - do_query($form, $dbh, $query, $form->{id}); - } + if (!$form->{id}) { + $query = qq|SELECT nextval('id')|; + ($form->{id}) = selectrow_query($form, $dbh, $query); - do_query($form, $dbh, qq|UPDATE warehouse SET description = ?, invalid = ? WHERE id = ?|, - $form->{description}, $form->{invalid} ? 't' : 'f', conv_i($form->{id})); + $query = qq|INSERT INTO warehouse (id, sortkey) VALUES (?, (SELECT COALESCE(MAX(sortkey), 0) + 1 FROM warehouse))|; + do_query($form, $dbh, $query, $form->{id}); + } - if (0 < $form->{number_of_new_bins}) { - my ($num_existing_bins) = selectfirst_array_query($form, $dbh, qq|SELECT COUNT(*) FROM bin WHERE warehouse_id = ?|, $form->{id}); - $query = qq|INSERT INTO bin (warehouse_id, description) VALUES (?, ?)|; - $sth = prepare_query($form, $dbh, $query); + do_query($form, $dbh, qq|UPDATE warehouse SET description = ?, invalid = ? WHERE id = ?|, + $form->{description}, $form->{invalid} ? 't' : 'f', conv_i($form->{id})); - foreach my $i (1..$form->{number_of_new_bins}) { - do_statement($form, $sth, $query, conv_i($form->{id}), "$form->{prefix}" . ($i + $num_existing_bins)); - } + if (0 < $form->{number_of_new_bins}) { + my ($num_existing_bins) = selectfirst_array_query($form, $dbh, qq|SELECT COUNT(*) FROM bin WHERE warehouse_id = ?|, $form->{id}); + $query = qq|INSERT INTO bin (warehouse_id, description) VALUES (?, ?)|; + $sth = prepare_query($form, $dbh, $query); - $sth->finish(); - } + foreach my $i (1..$form->{number_of_new_bins}) { + do_statement($form, $sth, $query, conv_i($form->{id}), "$form->{prefix}" . ($i + $num_existing_bins)); + } - $dbh->commit(); + $sth->finish(); + } + 1; + }) or do { die SL::DB->client->error }; $main::lxdebug->leave_sub(); } @@ -1531,34 +1491,30 @@ sub save_bins { my ($self, $myconfig, $form) = @_; - # connect to database - my $dbh = $form->get_standard_dbh($myconfig); - - my ($query, @values, $commit_necessary, $sth); - - @values = map { $form->{"id_${_}"} } grep { $form->{"delete_${_}"} } (1..$form->{rowcount}); + SL::DB->client->with_transaction(sub { + my $dbh = SL::DB->client->dbh; - if (@values) { - $query = qq|DELETE FROM bin WHERE id IN (| . join(', ', ('?') x scalar(@values)) . qq|)|; - do_query($form, $dbh, $query, @values); + my ($query, @values, $sth); - $commit_necessary = 1; - } + @values = map { $form->{"id_${_}"} } grep { $form->{"delete_${_}"} } (1..$form->{rowcount}); - $query = qq|UPDATE bin SET description = ? WHERE id = ?|; - $sth = prepare_query($form, $dbh, $query); - - foreach my $row (1..$form->{rowcount}) { - next if ($form->{"delete_${row}"}); + if (@values) { + $query = qq|DELETE FROM bin WHERE id IN (| . join(', ', ('?') x scalar(@values)) . qq|)|; + do_query($form, $dbh, $query, @values); + } - do_statement($form, $sth, $query, $form->{"description_${row}"}, conv_i($form->{"id_${row}"})); + $query = qq|UPDATE bin SET description = ? WHERE id = ?|; + $sth = prepare_query($form, $dbh, $query); - $commit_necessary = 1; - } + foreach my $row (1..$form->{rowcount}) { + next if ($form->{"delete_${row}"}); - $sth->finish(); + do_statement($form, $sth, $query, $form->{"description_${row}"}, conv_i($form->{"id_${row}"})); + } - $dbh->commit() if ($commit_necessary); + $sth->finish(); + 1; + }) or do { die SL::DB->client->error }; $main::lxdebug->leave_sub(); } @@ -1568,26 +1524,26 @@ sub delete_warehouse { my ($self, $myconfig, $form) = @_; - # connect to database - my $dbh = $form->get_standard_dbh($myconfig); + my $rc = SL::DB->client->with_transaction(sub { + my $dbh = SL::DB->client->dbh; - my $id = conv_i($form->{id}); - my $query = qq|SELECT i.bin_id FROM inventory i WHERE i.bin_id IN (SELECT b.id FROM bin b WHERE b.warehouse_id = ?) LIMIT 1|; - my ($count) = selectrow_query($form, $dbh, $query, $id); + my $id = conv_i($form->{id}); + my $query = qq|SELECT i.bin_id FROM inventory i WHERE i.bin_id IN (SELECT b.id FROM bin b WHERE b.warehouse_id = ?) LIMIT 1|; + my ($count) = selectrow_query($form, $dbh, $query, $id); - if ($count) { - $main::lxdebug->leave_sub(); - return 0; - } + if ($count) { + return 0; + } - do_query($form, $dbh, qq|DELETE FROM bin WHERE warehouse_id = ?|, conv_i($form->{id})); - do_query($form, $dbh, qq|DELETE FROM warehouse WHERE id = ?|, conv_i($form->{id})); + do_query($form, $dbh, qq|DELETE FROM bin WHERE warehouse_id = ?|, conv_i($form->{id})); + do_query($form, $dbh, qq|DELETE FROM warehouse WHERE id = ?|, conv_i($form->{id})); - $dbh->commit(); + return 1; + }); $main::lxdebug->leave_sub(); - return 1; + return $rc; } sub get_all_warehouses { @@ -1595,8 +1551,7 @@ sub get_all_warehouses { my ($self, $myconfig, $form) = @_; - # connect to database - my $dbh = $form->get_standard_dbh($myconfig); + my $dbh = SL::DB->client->dbh; my $query = qq|SELECT w.id, w.description, w.invalid, (SELECT COUNT(b.description) FROM bin b WHERE b.warehouse_id = w.id) AS number_of_bins @@ -1613,8 +1568,7 @@ sub get_warehouse { my ($self, $myconfig, $form) = @_; - # connect to database - my $dbh = $form->get_standard_dbh($myconfig); + my $dbh = SL::DB->client->dbh; my $id = conv_i($form->{id}); my $query = qq|SELECT w.description, w.invalid