X-Git-Url: http://wagnertech.de/git?a=blobdiff_plain;f=SL%2FAM.pm;h=323556bd4ae1d3dbf7d9b231b7b2d6805c4dfecf;hb=f8f101f30251b63e62e36e2aec1d6986e3167f78;hp=d1c281a8df07f6ad5a3b08c8a11b1e2df9c5473d;hpb=a00ef54be3986276bc8423683e72d62ea8fbaa54;p=kivitendo-erp.git diff --git a/SL/AM.pm b/SL/AM.pm index d1c281a8d..323556bd4 100644 --- a/SL/AM.pm +++ b/SL/AM.pm @@ -48,7 +48,7 @@ sub get_account { # connect to database my $dbh = $form->dbconnect($myconfig); my $query = - qq!SELECT c.accno, c.description, c.charttype, c.gifi_accno, c.category,! . + qq!SELECT c.accno, c.description, c.charttype, c.category,! . qq! c.link, c.pos_bilanz, c.pos_eur, c.new_chart_id, c.valid_from, ! . qq! c.pos_bwa, ! . qq! tk.taxkey_id, tk.pos_ustva, tk.tax_id, ! . @@ -180,43 +180,41 @@ sub save_account { my ($tax_id, $taxkey) = split(/--/, $form->{tax}); my $startdate = $form->{startdate} ? $form->{startdate} : "1970-01-01"; - if ($form->{id} && $form->{orphaned}) { + if ($form->{id}) { $query = qq|UPDATE chart SET accno = ?, description = ?, charttype = ?, - gifi_accno = ?, category = ?, link = ?, + category = ?, link = ?, taxkey_id = ?, pos_ustva = ?, pos_bwa = ?, pos_bilanz = ?, pos_eur = ?, new_chart_id = ?, valid_from = ? - WHERE id = ?|; + WHERE id = ?|; @values = ($form->{accno}, $form->{description}, $form->{charttype}, - $form->{gifi_accno}, $form->{category}, $form->{link}, - conv_i($taxkey), - conv_i($form->{pos_ustva}), conv_i($form->{pos_bwa}), - conv_i($form->{pos_bilanz}), conv_i($form->{pos_eur}), - conv_i($form->{new_chart_id}), - conv_date($form->{valid_from}), - $form->{id}); + $form->{category}, $form->{link}, + conv_i($taxkey), + conv_i($form->{pos_ustva}), conv_i($form->{pos_bwa}), + conv_i($form->{pos_bilanz}), conv_i($form->{pos_eur}), + conv_i($form->{new_chart_id}), + conv_date($form->{valid_from}), + $form->{id}); } elsif ($form->{id} && !$form->{new_chart_valid}) { $query = qq|UPDATE chart SET new_chart_id = ?, valid_from = ? - WHERE id = ?|; + WHERE id = ?|; @values = (conv_i($form->{new_chart_id}), conv_date($form->{valid_from}), - $form->{id}); + $form->{id}); } else { $query = qq|INSERT INTO chart (accno, description, charttype, - gifi_accno, category, link, - taxkey_id, + category, link, taxkey_id, pos_ustva, pos_bwa, pos_bilanz, pos_eur, new_chart_id, valid_from) VALUES (?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?)|; @values = ($form->{accno}, $form->{description}, $form->{charttype}, - $form->{gifi_accno}, $form->{category}, $form->{link}, - conv_i($taxkey), - conv_i($form->{pos_ustva}), conv_i($form->{pos_bwa}), - conv_i($form->{pos_bilanz}), conv_i($form->{pos_eur}), - conv_i($form->{new_chart_id}), - conv_date($form->{valid_from})); + $form->{category}, $form->{link}, conv_i($taxkey), + conv_i($form->{pos_ustva}), conv_i($form->{pos_bwa}), + conv_i($form->{pos_bilanz}), conv_i($form->{pos_eur}), + conv_i($form->{new_chart_id}), + conv_date($form->{valid_from})); } do_query($form, $dbh, $query, @values); @@ -228,8 +226,8 @@ sub save_account { qq|(chart_id, tax_id, taxkey_id, pos_ustva, startdate) | . qq|VALUES ((SELECT id FROM chart WHERE accno = ?), ?, ?, ?, ?)|; do_query($form, $dbh, $query, - $form->{accno}, conv_i($tax_id), conv_i($taxkey), - conv_i($form->{pos_ustva}), conv_date($startdate)); + $form->{accno}, conv_i($tax_id), conv_i($taxkey), + conv_i($form->{pos_ustva}), conv_date($startdate)); } else { $query = qq|DELETE FROM taxkeys WHERE chart_id = ? AND tax_id = ?|; @@ -240,8 +238,8 @@ sub save_account { qq|(chart_id, tax_id, taxkey_id, pos_ustva, startdate) | . qq|VALUES (?, ?, ?, ?, ?)|; do_query($form, $dbh, $query, - $form->{id}, conv_i($tax_id), conv_i($taxkey), - conv_i($form->{pos_ustva}), conv_date($startdate)); + $form->{id}, conv_i($tax_id), conv_i($taxkey), + conv_i($form->{pos_ustva}), conv_date($startdate)); } # commit @@ -300,217 +298,6 @@ sub delete_account { return $rc; } -sub gifi_accounts { - $main::lxdebug->enter_sub(); - - my ($self, $myconfig, $form) = @_; - - # connect to database - my $dbh = $form->dbconnect($myconfig); - - my $query = qq|SELECT accno, description - FROM gifi - ORDER BY accno|; - - $sth = $dbh->prepare($query); - $sth->execute || $form->dberror($query); - - while (my $ref = $sth->fetchrow_hashref(NAME_lc)) { - push @{ $form->{ALL} }, $ref; - } - - $sth->finish; - $dbh->disconnect; - - $main::lxdebug->leave_sub(); -} - -sub get_gifi { - $main::lxdebug->enter_sub(); - - my ($self, $myconfig, $form) = @_; - - # connect to database - my $dbh = $form->dbconnect($myconfig); - - my $query = qq|SELECT g.accno, g.description - FROM gifi g - WHERE g.accno = '$form->{accno}'|; - my $sth = $dbh->prepare($query); - $sth->execute || $form->dberror($query); - - my $ref = $sth->fetchrow_hashref(NAME_lc); - - map { $form->{$_} = $ref->{$_} } keys %$ref; - - $sth->finish; - - # check for transactions - $query = qq|SELECT count(*) FROM acc_trans a, chart c, gifi g - WHERE c.gifi_accno = g.accno - AND a.chart_id = c.id - AND g.accno = '$form->{accno}'|; - $sth = $dbh->prepare($query); - $sth->execute || $form->dberror($query); - - ($form->{orphaned}) = $sth->fetchrow_array; - $sth->finish; - $form->{orphaned} = !$form->{orphaned}; - - $dbh->disconnect; - - $main::lxdebug->leave_sub(); -} - -sub save_gifi { - $main::lxdebug->enter_sub(); - - my ($self, $myconfig, $form) = @_; - - # connect to database - my $dbh = $form->dbconnect($myconfig); - - $form->{description} =~ s/\'/\'\'/g; - - # id is the old account number! - if ($form->{id}) { - $query = qq|UPDATE gifi SET - accno = '$form->{accno}', - description = '$form->{description}' - WHERE accno = '$form->{id}'|; - } else { - $query = qq|INSERT INTO gifi - (accno, description) - VALUES ('$form->{accno}', '$form->{description}')|; - } - $dbh->do($query) || $form->dberror($query); - - $dbh->disconnect; - - $main::lxdebug->leave_sub(); -} - -sub delete_gifi { - $main::lxdebug->enter_sub(); - - my ($self, $myconfig, $form) = @_; - - # connect to database - my $dbh = $form->dbconnect($myconfig); - - # id is the old account number! - $query = qq|DELETE FROM gifi - WHERE accno = '$form->{id}'|; - $dbh->do($query) || $form->dberror($query); - - $dbh->disconnect; - - $main::lxdebug->leave_sub(); -} - -sub warehouses { - $main::lxdebug->enter_sub(); - - my ($self, $myconfig, $form) = @_; - - # connect to database - my $dbh = $form->dbconnect($myconfig); - - my $query = qq|SELECT id, description - FROM warehouse - ORDER BY 2|; - - $sth = $dbh->prepare($query); - $sth->execute || $form->dberror($query); - - while (my $ref = $sth->fetchrow_hashref(NAME_lc)) { - push @{ $form->{ALL} }, $ref; - } - - $sth->finish; - $dbh->disconnect; - - $main::lxdebug->leave_sub(); -} - -sub get_warehouse { - $main::lxdebug->enter_sub(); - - my ($self, $myconfig, $form) = @_; - - # connect to database - my $dbh = $form->dbconnect($myconfig); - - my $query = qq|SELECT w.description - FROM warehouse w - WHERE w.id = $form->{id}|; - my $sth = $dbh->prepare($query); - $sth->execute || $form->dberror($query); - - my $ref = $sth->fetchrow_hashref(NAME_lc); - - map { $form->{$_} = $ref->{$_} } keys %$ref; - - $sth->finish; - - # see if it is in use - $query = qq|SELECT count(*) FROM inventory i - WHERE i.warehouse_id = $form->{id}|; - $sth = $dbh->prepare($query); - $sth->execute || $form->dberror($query); - - ($form->{orphaned}) = $sth->fetchrow_array; - $form->{orphaned} = !$form->{orphaned}; - $sth->finish; - - $dbh->disconnect; - - $main::lxdebug->leave_sub(); -} - -sub save_warehouse { - $main::lxdebug->enter_sub(); - - my ($self, $myconfig, $form) = @_; - - # connect to database - my $dbh = $form->dbconnect($myconfig); - - $form->{description} =~ s/\'/\'\'/g; - - if ($form->{id}) { - $query = qq|UPDATE warehouse SET - description = '$form->{description}' - WHERE id = $form->{id}|; - } else { - $query = qq|INSERT INTO warehouse - (description) - VALUES ('$form->{description}')|; - } - $dbh->do($query) || $form->dberror($query); - - $dbh->disconnect; - - $main::lxdebug->leave_sub(); -} - -sub delete_warehouse { - $main::lxdebug->enter_sub(); - - my ($self, $myconfig, $form) = @_; - - # connect to database - my $dbh = $form->dbconnect($myconfig); - - $query = qq|DELETE FROM warehouse - WHERE id = $form->{id}|; - $dbh->do($query) || $form->dberror($query); - - $dbh->disconnect; - - $main::lxdebug->leave_sub(); -} - sub departments { $main::lxdebug->enter_sub(); @@ -521,11 +308,12 @@ sub departments { my $query = qq|SELECT d.id, d.description, d.role FROM department d - ORDER BY 2|; + ORDER BY 2|; $sth = $dbh->prepare($query); $sth->execute || $form->dberror($query); + $form->{ALL} = []; while (my $ref = $sth->fetchrow_hashref(NAME_lc)) { push @{ $form->{ALL} }, $ref; } @@ -546,9 +334,9 @@ sub get_department { my $query = qq|SELECT d.description, d.role FROM department d - WHERE d.id = $form->{id}|; + WHERE d.id = ?|; my $sth = $dbh->prepare($query); - $sth->execute || $form->dberror($query); + $sth->execute($form->{id}) || $form->dberror($query . " ($form->{id})"); my $ref = $sth->fetchrow_hashref(NAME_lc); @@ -558,11 +346,9 @@ sub get_department { # see if it is in use $query = qq|SELECT count(*) FROM dpt_trans d - WHERE d.department_id = $form->{id}|; - $sth = $dbh->prepare($query); - $sth->execute || $form->dberror($query); + WHERE d.department_id = ?|; + ($form->{orphaned}) = selectrow_query($form, $dbh, $query, $form->{id}); - ($form->{orphaned}) = $sth->fetchrow_array; $form->{orphaned} = !$form->{orphaned}; $sth->finish; @@ -579,19 +365,18 @@ sub save_department { # connect to database my $dbh = $form->dbconnect($myconfig); - $form->{description} =~ s/\'/\'\'/g; - + my @values = ($form->{description}, $form->{role}); if ($form->{id}) { $query = qq|UPDATE department SET - description = '$form->{description}', - role = '$form->{role}' - WHERE id = $form->{id}|; + description = ?, role = ? + WHERE id = ?|; + push(@values, $form->{id}); } else { $query = qq|INSERT INTO department (description, role) - VALUES ('$form->{description}', '$form->{role}')|; + VALUES (?, ?)|; } - $dbh->do($query) || $form->dberror($query); + do_query($form, $dbh, $query, @values); $dbh->disconnect; @@ -607,8 +392,8 @@ sub delete_department { my $dbh = $form->dbconnect($myconfig); $query = qq|DELETE FROM department - WHERE id = $form->{id}|; - $dbh->do($query) || $form->dberror($query); + WHERE id = ?|; + do_query($form, $dbh, $query, $form->{id}); $dbh->disconnect; @@ -625,11 +410,12 @@ sub lead { my $query = qq|SELECT id, lead FROM leads - ORDER BY 2|; + ORDER BY 2|; $sth = $dbh->prepare($query); $sth->execute || $form->dberror($query); + $form->{ALL}; while (my $ref = $sth->fetchrow_hashref(NAME_lc)) { push @{ $form->{ALL} }, $ref; } @@ -649,11 +435,11 @@ sub get_lead { my $dbh = $form->dbconnect($myconfig); my $query = - qq|SELECT l.id, l.lead - FROM leads l - WHERE l.id = $form->{id}|; + qq|SELECT l.id, l.lead | . + qq|FROM leads l | . + qq|WHERE l.id = ?|; my $sth = $dbh->prepare($query); - $sth->execute || $form->dberror($query); + $sth->execute($form->{id}) || $form->dberror($query . " ($form->{id})"); my $ref = $sth->fetchrow_hashref(NAME_lc); @@ -674,19 +460,19 @@ sub save_lead { # connect to database my $dbh = $form->dbconnect($myconfig); - $form->{lead} =~ s/\'/\'\'/g; - + my @values = ($form->{description}); # id is the old record if ($form->{id}) { $query = qq|UPDATE leads SET - lead = '$form->{description}' - WHERE id = $form->{id}|; + lead = ? + WHERE id = ?|; + puhs(@values, $form->{id}); } else { $query = qq|INSERT INTO leads (lead) - VALUES ('$form->{description}')|; + VALUES (?)|; } - $dbh->do($query) || $form->dberror($query); + do_query($form, $dbh, $query, @values); $dbh->disconnect; @@ -702,8 +488,8 @@ sub delete_lead { my $dbh = $form->dbconnect($myconfig); $query = qq|DELETE FROM leads - WHERE id = $form->{id}|; - $dbh->do($query) || $form->dberror($query); + WHERE id = ?|; + do_query($form, $dbh, $query, $form->{id}); $dbh->disconnect; @@ -718,13 +504,14 @@ sub business { # connect to database my $dbh = $form->dbconnect($myconfig); - my $query = qq|SELECT id, description, discount, customernumberinit, salesman + my $query = qq|SELECT id, description, discount, customernumberinit FROM business - ORDER BY 2|; + ORDER BY 2|; $sth = $dbh->prepare($query); $sth->execute || $form->dberror($query); + $form->{ALL}; while (my $ref = $sth->fetchrow_hashref(NAME_lc)) { push @{ $form->{ALL} }, $ref; } @@ -744,11 +531,11 @@ sub get_business { my $dbh = $form->dbconnect($myconfig); my $query = - qq|SELECT b.description, b.discount, b.customernumberinit, b.salesman - FROM business b - WHERE b.id = $form->{id}|; + qq|SELECT b.description, b.discount, b.customernumberinit + FROM business b + WHERE b.id = ?|; my $sth = $dbh->prepare($query); - $sth->execute || $form->dberror($query); + $sth->execute($form->{id}) || $form->dberror($query . " ($form->{id})"); my $ref = $sth->fetchrow_hashref(NAME_lc); @@ -769,24 +556,22 @@ sub save_business { # connect to database my $dbh = $form->dbconnect($myconfig); - $form->{description} =~ s/\'/\'\'/g; - $form->{discount} /= 100; - $form->{salesman} *= 1; - + my @values = ($form->{description}, $form->{discount}, + $form->{customernumberinit}); # id is the old record if ($form->{id}) { $query = qq|UPDATE business SET - description = '$form->{description}', - discount = $form->{discount}, - customernumberinit = '$form->{customernumberinit}', - salesman = '$form->{salesman}' - WHERE id = $form->{id}|; + description = ?, + discount = ?, + customernumberinit = ? + WHERE id = ?|; + push(@values, $form->{id}); } else { $query = qq|INSERT INTO business - (description, discount, customernumberinit, salesman) - VALUES ('$form->{description}', $form->{discount}, '$form->{customernumberinit}', '$form->{salesman}')|; + (description, discount, customernumberinit) + VALUES (?, ?, ?)|; } - $dbh->do($query) || $form->dberror($query); + do_query($form, $dbh, $query, @values); $dbh->disconnect; @@ -802,8 +587,8 @@ sub delete_business { my $dbh = $form->dbconnect($myconfig); $query = qq|DELETE FROM business - WHERE id = $form->{id}|; - $dbh->do($query) || $form->dberror($query); + WHERE id = ?|; + do_query($form, $dbh, $query, $form->{id}); $dbh->disconnect; @@ -883,7 +668,7 @@ sub get_language_details { "SELECT template_code, " . " output_numberformat, output_dateformat, output_longdates " . "FROM language WHERE id = ?"; - my @res = $dbh->selectrow_array($query, undef, $id); + my @res = selectrow_query($form, $dbh, $query, $id); $dbh->disconnect; $main::lxdebug->leave_sub(); @@ -920,8 +705,7 @@ sub save_language { " output_numberformat, output_dateformat, output_longdates" . ") VALUES (?, ?, ?, ?, ?, ?)"; } - $dbh->do($query, undef, @values) || - $form->dberror($query . " (" . join(", ", @values) . ")"); + do_query($form, $dbh, $query, @values); $dbh->disconnect; @@ -1038,14 +822,13 @@ sub get_buchungsgruppe { qq|SELECT count(id) = 0 AS orphaned FROM parts WHERE buchungsgruppen_id = ?|; - ($form->{orphaned}) = $dbh->selectrow_array($query, undef, $form->{id}); - $form->dberror($query . " ($form->{id})") if ($dbh->err); + ($form->{orphaned}) = selectrow_query($form, $dbh, $query, $form->{id}); } $query = "SELECT inventory_accno_id, income_accno_id, expense_accno_id ". "FROM defaults"; ($form->{"std_inventory_accno_id"}, $form->{"std_income_accno_id"}, - $form->{"std_expense_accno_id"}) = $dbh->selectrow_array($query); + $form->{"std_expense_accno_id"}) = selectrow_query($form, $dbh, $query); my $module = "IC"; $query = qq|SELECT c.accno, c.description, c.link, c.id, @@ -1193,7 +976,7 @@ sub printer { my $query = qq|SELECT id, printer_description, template_code, printer_command FROM printers - ORDER BY 2|; + ORDER BY 2|; $sth = $dbh->prepare($query); $sth->execute || $form->dberror($query); @@ -1219,10 +1002,10 @@ sub get_printer { my $query = qq|SELECT p.printer_description, p.template_code, p.printer_command - FROM printers p - WHERE p.id = $form->{id}|; + FROM printers p + WHERE p.id = ?|; my $sth = $dbh->prepare($query); - $sth->execute || $form->dberror($query); + $sth->execute($form->{id}) || $form->dberror($query . " ($form->{id})"); my $ref = $sth->fetchrow_hashref(NAME_lc); @@ -1243,24 +1026,22 @@ sub save_printer { # connect to database my $dbh = $form->dbconnect($myconfig); - $form->{printer_description} =~ s/\'/\'\'/g; - $form->{printer_command} =~ s/\'/\'\'/g; - $form->{template_code} =~ s/\'/\'\'/g; - + my @values = ($form->{printer_description}, + $form->{template_code}, + $form->{printer_command}); # id is the old record if ($form->{id}) { $query = qq|UPDATE printers SET - printer_description = '$form->{printer_description}', - template_code = '$form->{template_code}', - printer_command = '$form->{printer_command}' - WHERE id = $form->{id}|; + printer_description = ?, template_code = ?, printer_command = ? + WHERE id = ?|; + push(@values, $form->{id}); } else { $query = qq|INSERT INTO printers (printer_description, template_code, printer_command) - VALUES ('$form->{printer_description}', '$form->{template_code}', '$form->{printer_command}')|; + VALUES (?, ?, ?)|; } - $dbh->do($query) || $form->dberror($query); + do_query($form, $dbh, $query, @values); $dbh->disconnect; @@ -1276,8 +1057,8 @@ sub delete_printer { my $dbh = $form->dbconnect($myconfig); $query = qq|DELETE FROM printers - WHERE id = $form->{id}|; - $dbh->do($query) || $form->dberror($query); + WHERE id = ?|; + do_query($form, $dbh, $query, $form->{id}); $dbh->disconnect; @@ -1331,7 +1112,7 @@ sub get_payment { qq|WHERE t.payment_terms_id = ? | . qq|UNION | . qq|SELECT l.id AS language_id, NULL AS description_long, | . - qq|l.description AS language | . + qq| l.description AS language | . qq|FROM language l|; $sth = $dbh->prepare($query); $sth->execute($form->{"id"}) || $form->dberror($query . " ($form->{id})"); @@ -1439,133 +1220,85 @@ sub delete_payment { $main::lxdebug->leave_sub(); } -sub sic { - $main::lxdebug->enter_sub(); - - my ($self, $myconfig, $form) = @_; - - # connect to database - my $dbh = $form->dbconnect($myconfig); - - my $query = qq|SELECT code, sictype, description - FROM sic - ORDER BY code|; - - $sth = $dbh->prepare($query); - $sth->execute || $form->dberror($query); - - while (my $ref = $sth->fetchrow_hashref(NAME_lc)) { - push @{ $form->{ALL} }, $ref; - } - - $sth->finish; - $dbh->disconnect; - - $main::lxdebug->leave_sub(); -} -sub get_sic { +sub prepare_template_filename { $main::lxdebug->enter_sub(); my ($self, $myconfig, $form) = @_; - # connect to database - my $dbh = $form->dbconnect($myconfig); - - my $query = qq|SELECT s.code, s.sictype, s.description - FROM sic s - WHERE s.code = '$form->{code}'|; - my $sth = $dbh->prepare($query); - $sth->execute || $form->dberror($query); - - my $ref = $sth->fetchrow_hashref(NAME_lc); - - map { $form->{$_} = $ref->{$_} } keys %$ref; - - $sth->finish; - - $dbh->disconnect; - - $main::lxdebug->leave_sub(); -} + my ($filename, $display_filename); -sub save_sic { - $main::lxdebug->enter_sub(); + if ($form->{type} eq "stylesheet") { + $filename = "css/$myconfig->{stylesheet}"; + $display_filename = $myconfig->{stylesheet}; - my ($self, $myconfig, $form) = @_; + } else { + $filename = $form->{formname}; - # connect to database - my $dbh = $form->dbconnect($myconfig); + if ($form->{language}) { + my ($id, $template_code) = split(/--/, $form->{language}); + $filename .= "_${template_code}"; + } - $form->{code} =~ s/\'/\'\'/g; - $form->{description} =~ s/\'/\'\'/g; + if ($form->{printer}) { + my ($id, $template_code) = split(/--/, $form->{printer}); + $filename .= "_${template_code}"; + } - # if there is an id - if ($form->{id}) { - $query = qq|UPDATE sic SET - code = '$form->{code}', - sictype = '$form->{sictype}', - description = '$form->{description}' - WHERE code = '$form->{id}'|; - } else { - $query = qq|INSERT INTO sic - (code, sictype, description) - VALUES ('$form->{code}', '$form->{sictype}', '$form->{description}')|; + $filename .= "." . ($form->{format} eq "html" ? "html" : "tex"); + $filename =~ s|.*/||; + $display_filename = $filename; + $filename = "$myconfig->{templates}/$filename"; } - $dbh->do($query) || $form->dberror($query); - - $dbh->disconnect; $main::lxdebug->leave_sub(); -} - -sub delete_sic { - $main::lxdebug->enter_sub(); - - my ($self, $myconfig, $form) = @_; - - # connect to database - my $dbh = $form->dbconnect($myconfig); - - $query = qq|DELETE FROM sic - WHERE code = '$form->{code}'|; - $dbh->do($query) || $form->dberror($query); - - $dbh->disconnect; - $main::lxdebug->leave_sub(); + return ($filename, $display_filename); } + sub load_template { $main::lxdebug->enter_sub(); - my ($self, $form) = @_; + my ($self, $filename) = @_; - open(TEMPLATE, "$form->{file}") or $form->error("$form->{file} : $!"); + my ($content, $lines) = ("", 0); - while (