X-Git-Url: http://wagnertech.de/git?a=blobdiff_plain;f=SL%2FRecordLinks.pm;h=da5d54abb74b828d4ddfb0ee510a481f64bc3b05;hb=991369b17d679e2855f4d5086d0b9769dc2ae1aa;hp=cef2c4df0e7aee8e5186a1d8d9601793919e2cb9;hpb=8d011bee4d01444862f49a083f9e47b2b07f0a9c;p=kivitendo-erp.git diff --git a/SL/RecordLinks.pm b/SL/RecordLinks.pm index cef2c4df0..da5d54abb 100644 --- a/SL/RecordLinks.pm +++ b/SL/RecordLinks.pm @@ -7,6 +7,7 @@ use SL::Common; use SL::DBUtils; use Data::Dumper; use List::Util qw(reduce); +use SL::DB; sub create_links { $main::lxdebug->enter_sub(); @@ -54,19 +55,21 @@ sub create_links { my $myconfig = \%main::myconfig; my $form = $main::form; - my $dbh = $params{dbh} || $form->get_standard_dbh($myconfig); + SL::DB->client->with_transaction(sub { + my $dbh = $params{dbh} || SL::DB->client->dbh; - my $query = qq|INSERT INTO record_links (from_table, from_id, to_table, to_id) VALUES (?, ?, ?, ?)|; - my $sth = prepare_query($form, $dbh, $query); + my $query = qq|INSERT INTO record_links (from_table, from_id, to_table, to_id) VALUES (?, ?, ?, ?)|; + my $sth = prepare_query($form, $dbh, $query); - foreach my $link (@links) { - next if ('HASH' ne ref $link); - next if (!$link->{from_table} || !$link->{from_id} || !$link->{to_table} || !$link->{to_id}); + foreach my $link (@links) { + next if ('HASH' ne ref $link); + next if (!$link->{from_table} || !$link->{from_id} || !$link->{to_table} || !$link->{to_id}); - do_statement($form, $sth, $query, $link->{from_table}, conv_i($link->{from_id}), $link->{to_table}, conv_i($link->{to_id})); - } + do_statement($form, $sth, $query, $link->{from_table}, conv_i($link->{from_id}), $link->{to_table}, conv_i($link->{to_id})); + } - $dbh->commit() unless ($params{dbh}); + 1; + }) or do { die SL::DB->client->error }; $main::lxdebug->leave_sub(); } @@ -184,21 +187,23 @@ sub delete { my $myconfig = \%main::myconfig; my $form = $main::form; - my $dbh = $params{dbh} || $form->get_standard_dbh($myconfig); + SL::DB->client->with_transaction(sub { + my $dbh = $params{dbh} || SL::DB->client->dbh; - # content - my (@where_tokens, @where_values); + # content + my (@where_tokens, @where_values); - for my $col (qw(from_table from_id to_table to_id)) { - add_token(\@where_tokens, \@where_values, col => $col, val => $params{$col}) if $params{$col}; - } + for my $col (qw(from_table from_id to_table to_id)) { + add_token(\@where_tokens, \@where_values, col => $col, val => $params{$col}) if $params{$col}; + } - my $where = "WHERE ". join ' AND ', map { "($_)" } @where_tokens if scalar @where_tokens; - my $query = "DELETE FROM record_links $where"; + my $where = @where_tokens ? "WHERE ". join ' AND ', map { "($_)" } @where_tokens : ''; + my $query = "DELETE FROM record_links $where"; - do_query($form, $dbh, $query, @where_values); + do_query($form, $dbh, $query, @where_values); - $dbh->commit() unless ($params{dbh}); + 1; + }) or die { SL::DB->client->error }; $main::lxdebug->leave_sub(); } @@ -207,9 +212,13 @@ sub delete { __END__ +=pod + +=encoding utf8 + =head1 NAME -SL::RecordLinks - Verlinkung von Lx-Office Objekten. +SL::RecordLinks - Verlinkung von kivitendo Objekten. =head1 SYNOPSIS