X-Git-Url: http://wagnertech.de/git?a=blobdiff_plain;f=bin%2Fmozilla%2Fcommon.pl;h=f4a07f6674b29025799aafdebbcf6d02f4522c5f;hb=b5157f97d47413e5f33cced1d0de527979ff3d61;hp=ff5cc7537e740f9ccd25adad6586469311579c85;hpb=a7b15deeb326dc689e3a1593e4395163d78b3d6e;p=kivitendo-erp.git diff --git a/bin/mozilla/common.pl b/bin/mozilla/common.pl index ff5cc7537..f4a07f667 100644 --- a/bin/mozilla/common.pl +++ b/bin/mozilla/common.pl @@ -47,7 +47,7 @@ sub build_std_url { my $url = "$form->{script}?"; my $first = 1; - foreach my $key ((qw(login password path), @_)) { + foreach my $key ((qw(login password), @_)) { next unless ($key); $url .= "&" unless ($first); $first = 0; @@ -97,7 +97,7 @@ sub select_employee_internal { restore_form($form->{"old_form"}); - &{ $callback_sub }($new_id, $new_name); + call_sub($callback_sub, $new_id, $new_name); $lxdebug->leave_sub(); } @@ -167,7 +167,7 @@ sub select_part_internal { restore_form($form->{"old_form"}); - &{ $callback_sub }($new_item); + call_sub($callback_sub, $new_item); $lxdebug->leave_sub(); } @@ -543,4 +543,24 @@ sub show_history { $lxdebug->leave_sub(); } +sub call_sub { + $lxdebug->enter_sub(); + + my $name = shift; + + if (!$name) { + $form->error($locale->text("Trying to call a sub without a name")); + } + + $name =~ s/[^a-zA-Z0-9_]//g; + + if (!defined(&{ $name })) { + $form->error(sprintf($locale->text("Attempt to call an undefined sub named '%s'"), $name)); + } + + &{ $name }(@_); + + $lxdebug->leave_sub(); +} + 1;