X-Git-Url: http://wagnertech.de/gitweb/gitweb.cgi/mfinanz.git/blobdiff_plain/62726dfdf4f763efa65c25fcfe8658d98649c8a8..862bc8ce30cd40b67d2856ac7f1d11d5e4322f09:/SL/Controller/Draft.pm?ds=inline diff --git a/SL/Controller/Draft.pm b/SL/Controller/Draft.pm index 33da3bd1a..41c8c1688 100644 --- a/SL/Controller/Draft.pm +++ b/SL/Controller/Draft.pm @@ -19,7 +19,7 @@ use Rose::Object::MakeMethods::Generic ( __PACKAGE__->run_before('check_auth'); -my %allowed_modules = map { $_ => "bin/mozilla/$_.pl" } qw(is ir ar ap); +my %allowed_modules = map { $_ => "bin/mozilla/$_.pl" } qw(is ir ar ap gl); # # actions @@ -82,10 +82,16 @@ sub action_load { require $allowed_modules{ $self->draft->module }; } + + my $params = delete $::form->{form}; my $new_form = YAML::Load($self->draft->form); $::form->{$_} = $new_form->{$_} for keys %$new_form; $::form->{"draft_$_"} = $self->draft->$_ for qw(id description); + if ($params && 'HASH' eq ref $params) { + $::form->{$_} = $params->{$_} for keys %$params; + } + $::form->{script} = $self->draft->module . '.pl'; ::update(); } @@ -158,7 +164,7 @@ sub init_draft { } sub check_auth { - $::auth->assert('vendor_invoice_edit | invoice_edit | general_ledger'); + $::auth->assert('vendor_invoice_edit | invoice_edit | ap_transactions | ar_transactions'); } 1;