From: Jan Büren Date: Wed, 7 Nov 2012 10:58:16 +0000 (+0100) Subject: Merge branch 'master' of vc.linet-services.de:public/lx-office-erp X-Git-Tag: release-3.0.0beta1~48^2^2~2 X-Git-Url: http://wagnertech.de/gitweb/gitweb.cgi/mfinanz.git/commitdiff_plain/9d218dc8b07ff4f9be9589cb3246e50653e2b6e2?hp=075bd42af8885aee3c18fe055a2c82b8b43f4cea Merge branch 'master' of vc.linet-services.de:public/lx-office-erp --- diff --git a/SL/AM.pm b/SL/AM.pm index 1a085b8bd..6862eb773 100644 --- a/SL/AM.pm +++ b/SL/AM.pm @@ -243,6 +243,18 @@ sub save_account { $form->{id} = ""; } + $query = ' + SELECT + accno + FROM chart + WHERE accno = ?'; + my ($accno) = selectrow_query($form, $dbh, $query, $form->{accno}); + + if ($accno) { + $form->error($::locale->text('Account number not unique!')); + } + + if (!$form->{id} || $form->{id} eq "") { $query = qq|SELECT nextval('id')|; ($form->{"id"}) = selectrow_query($form, $dbh, $query); @@ -269,17 +281,6 @@ sub save_account { $form->{valid_from} = ''; }; - $query = ' - SELECT - accno - FROM chart - WHERE accno = ?'; - my ($accno) = selectrow_query($form, $dbh, $query, $form->{accno}); - - if ($accno) { - $form->error($::locale->text('Account number not unique!')); - } - $query = qq|UPDATE chart SET accno = ?, description = ?, diff --git a/SL/AP.pm b/SL/AP.pm index eda1e71f4..95bde38e5 100644 --- a/SL/AP.pm +++ b/SL/AP.pm @@ -38,7 +38,7 @@ use SL::DATEV qw(:CONSTANTS); use SL::DBUtils; use SL::IO; use SL::MoreCommon; - +use SL::DB::Default; use Data::Dumper; use strict; @@ -251,7 +251,7 @@ sub post_transaction { # add paid transactions for my $i (1 .. $form->{paidaccounts}) { - if ($form->{"acc_trans_id_$i"} && $payments_only && ($::lx_office_conf{features}->{payments_changeable} == 0)) { + if ($form->{"acc_trans_id_$i"} && $payments_only && (SL::DB::Default->get->payments_changeable == 0)) { next; } @@ -355,7 +355,7 @@ sub post_transaction { IO->set_datepaid(table => 'ap', id => $form->{id}, dbh => $dbh); # safety check datev export - if ($::lx_office_conf{datev_check}{check_on_ap_transaction}) { + if ($::instance_conf->get_datev_check_on_ap_transaction) { my $transdate = $::form->{transdate} ? DateTime->from_lxoffice($::form->{transdate}) : undef; $transdate ||= DateTime->today; @@ -593,7 +593,7 @@ sub post_payment { $old_form = save_form(); # Delete all entries in acc_trans from prior payments. - if ($::lx_office_conf{features}->{payments_changeable} != 0) { + if (SL::DB::Default->get->payments_changeable != 0) { $self->_delete_payments($form, $dbh); } diff --git a/SL/AR.pm b/SL/AR.pm index 8c72d3cf9..1f8a0c0f5 100644 --- a/SL/AR.pm +++ b/SL/AR.pm @@ -39,6 +39,7 @@ use SL::DATEV qw(:CONSTANTS); use SL::DBUtils; use SL::IO; use SL::MoreCommon; +use SL::DB::Default; use strict; @@ -203,7 +204,7 @@ sub post_transaction { # add paid transactions for my $i (1 .. $form->{paidaccounts}) { - if ($form->{"acc_trans_id_$i"} && $payments_only && ($::lx_office_conf{features}->{payments_changeable} == 0)) { + if ($form->{"acc_trans_id_$i"} && $payments_only && (SL::DB::Default->get->payments_changeable == 0)) { next; } @@ -275,7 +276,7 @@ sub post_transaction { IO->set_datepaid(table => 'ar', id => $form->{id}, dbh => $dbh); # safety check datev export - if ($::lx_office_conf{datev_check}{check_on_ar_transaction}) { + if ($::instance_conf->get_datev_check_on_ar_transaction) { my $transdate = $::form->{transdate} ? DateTime->from_lxoffice($::form->{transdate}) : undef; $transdate ||= DateTime->today; @@ -356,7 +357,7 @@ sub post_payment { $old_form = save_form(); # Delete all entries in acc_trans from prior payments. - if ($::lx_office_conf{features}->{payments_changeable} != 0) { + if (SL::DB::Default->get->payments_changeable != 0) { $self->_delete_payments($form, $dbh); } diff --git a/SL/BackgroundJob/Base.pm b/SL/BackgroundJob/Base.pm index 27f608129..912fdc6fd 100644 --- a/SL/BackgroundJob/Base.pm +++ b/SL/BackgroundJob/Base.pm @@ -4,7 +4,14 @@ use strict; use parent qw(Rose::Object); +use IO::Dir; use SL::DB::BackgroundJob; +use SL::System::Process; + +sub get_known_job_classes { + tie my %dir_h, 'IO::Dir', File::Spec->catdir(File::Spec->splitdir(SL::System::Process->exe_dir), 'SL', 'BackgroundJob'); + return sort map { s/\.pm$//; $_ } grep { m/\.pm$/ && !m/(?: ALL | Base) \.pm$/x } keys %dir_h; +} sub create_standard_job { my $self_or_class = shift; diff --git a/SL/Controller/BackgroundJob.pm b/SL/Controller/BackgroundJob.pm index 7729dafe1..797797782 100644 --- a/SL/Controller/BackgroundJob.pm +++ b/SL/Controller/BackgroundJob.pm @@ -4,6 +4,7 @@ use strict; use parent qw(SL::Controller::Base); +use SL::BackgroundJob::Base; use SL::Controller::Helper::GetModels; use SL::Controller::Helper::Paginated; use SL::Controller::Helper::Sorted; @@ -50,13 +51,18 @@ sub action_list { sub action_new { my ($self) = @_; - $self->background_job(SL::DB::BackgroundJob->new(cron_spec => '* * * * *')); - $self->render('background_job/form', title => $::locale->text('Create a new background job')); + $self->background_job(SL::DB::BackgroundJob->new(cron_spec => '* * * * *', package_name => 'Test')); + $self->render('background_job/form', + title => $::locale->text('Create a new background job'), + JOB_CLASSES => [ SL::BackgroundJob::Base->get_known_job_classes ]); } sub action_edit { my ($self) = @_; - $self->render('background_job/form', title => $::locale->text('Edit background job')); + + $self->render('background_job/form', + title => $::locale->text('Edit background job'), + JOB_CLASSES => [ SL::BackgroundJob::Base->get_known_job_classes ]); } sub action_create { diff --git a/SL/Controller/ClientConfig.pm b/SL/Controller/ClientConfig.pm new file mode 100644 index 000000000..aaed72fc5 --- /dev/null +++ b/SL/Controller/ClientConfig.pm @@ -0,0 +1,79 @@ +package SL::Controller::ClientConfig; + +use strict; +use parent qw(SL::Controller::Base); + +use SL::DB::Default; +use SL::Helper::Flash; + +__PACKAGE__->run_before('check_auth'); + + +sub action_edit { + my ($self, %params) = @_; + + $self->{posting_options} = [ { title => $::locale->text("never"), value => 0 }, + { title => $::locale->text("every time"), value => 1 }, + { title => $::locale->text("on the same day"), value => 2 }, ]; + $self->{payment_options} = [ { title => $::locale->text("never"), value => 0 }, + { title => $::locale->text("every time"), value => 1 }, + { title => $::locale->text("on the same day"), value => 2 }, ]; + $self->{accounting_options} = [ { title => $::locale->text("accrual"), value => "accrual" }, + { title => $::locale->text("cash"), value => "cash" }, ]; + $self->{inventory_options} = [ { title => $::locale->text("perpetual"), value => "perpetual" }, + { title => $::locale->text("periodic"), value => "periodic" }, ]; + $self->{profit_options} = [ { title => $::locale->text("balance"), value => "balance" }, + { title => $::locale->text("income"), value => "income" }, ]; + + map { $self->{$_} = SL::DB::Default->get->$_ } qw(is_changeable ir_changeable ar_changeable ap_changeable gl_changeable); + + $self->{payments_changeable} = SL::DB::Default->get->payments_changeable; + + map { $self->{$_} = SL::DB::Default->get->$_ } qw(is_show_mark_as_paid ir_show_mark_as_paid ar_show_mark_as_paid ap_show_mark_as_paid); + + map { $self->{$_} = SL::DB::Default->get->$_ } qw(accounting_method inventory_system profit_determination); + + $self->{show_bestbefore} = SL::DB::Default->get->show_bestbefore; + + map { $self->{$_} = SL::DB::Default->get->$_ } qw(datev_check_on_sales_invoice datev_check_on_purchase_invoice datev_check_on_ar_transaction datev_check_on_ap_transaction datev_check_on_gl_transaction); + # datev check: not implemented yet: + #check_on_cash_and_receipt = 0 + #check_on_dunning = 0 + #check_on_sepa_import = 0 + + map { $self->{$_} = SL::DB::Default->get->$_ } qw(sales_order_show_delete purchase_order_show_delete sales_delivery_order_show_delete purchase_delivery_order_show_delete); + + $self->render('client_config/form', title => $::locale->text('Client Configuration')); +} + + +sub action_save { + my ($self, %params) = @_; + + map { SL::DB::Default->get->update_attributes($_ => $::form->{$_}); } qw(is_changeable ir_changeable ar_changeable ap_changeable gl_changeable); + + SL::DB::Default->get->update_attributes('payments_changeable' => $::form->{payments_changeable}); + + map { SL::DB::Default->get->update_attributes($_ => $::form->{$_}); } qw(is_show_mark_as_paid ir_show_mark_as_paid ar_show_mark_as_paid ap_show_mark_as_paid); + + map { SL::DB::Default->get->update_attributes($_ => $::form->{$_}); } qw(accounting_method inventory_system profit_determination); + + SL::DB::Default->get->update_attributes('show_bestbefore' => $::form->{show_bestbefore}); + + map { SL::DB::Default->get->update_attributes($_ => $::form->{$_}); } qw(datev_check_on_sales_invoice datev_check_on_purchase_invoice datev_check_on_ar_transaction datev_check_on_ap_transaction datev_check_on_gl_transaction); + + map { SL::DB::Default->get->update_attributes($_ => $::form->{$_}); } qw(sales_order_show_delete purchase_order_show_delete sales_delivery_order_show_delete purchase_delivery_order_show_delete); + + flash_later('info', $::locale->text('Client Configuration saved!')); + + $self->redirect_to(action => 'edit'); +} + + +#################### private stuff ########################## + +sub check_auth { + $::auth->assert('admin'); +} + +1; diff --git a/SL/DB/MetaSetup/Default.pm b/SL/DB/MetaSetup/Default.pm index 53ecc68e9..9365eac9d 100644 --- a/SL/DB/MetaSetup/Default.pm +++ b/SL/DB/MetaSetup/Default.pm @@ -10,43 +10,63 @@ __PACKAGE__->meta->setup( table => 'defaults', columns => [ - inventory_accno_id => { type => 'integer' }, - income_accno_id => { type => 'integer' }, - expense_accno_id => { type => 'integer' }, - fxgain_accno_id => { type => 'integer' }, - fxloss_accno_id => { type => 'integer' }, - invnumber => { type => 'text' }, - sonumber => { type => 'text' }, - weightunit => { type => 'varchar', length => 5 }, - businessnumber => { type => 'text' }, - version => { type => 'varchar', length => 8 }, - curr => { type => 'text' }, - closedto => { type => 'date' }, - revtrans => { type => 'boolean', default => 'false' }, - ponumber => { type => 'text' }, - sqnumber => { type => 'text' }, - rfqnumber => { type => 'text' }, - customernumber => { type => 'text' }, - vendornumber => { type => 'text' }, - audittrail => { type => 'boolean', default => 'false' }, - articlenumber => { type => 'text' }, - servicenumber => { type => 'text' }, - coa => { type => 'text' }, - itime => { type => 'timestamp', default => 'now()' }, - mtime => { type => 'timestamp' }, - rmanumber => { type => 'text' }, - cnnumber => { type => 'text' }, - dunning_ar_amount_fee => { type => 'integer' }, - dunning_ar_amount_interest => { type => 'integer' }, - dunning_ar => { type => 'integer' }, - pdonumber => { type => 'text' }, - sdonumber => { type => 'text' }, - ar_paid_accno_id => { type => 'integer' }, - id => { type => 'serial', not_null => 1 }, - accounting_method => { type => 'text' }, - inventory_system => { type => 'text' }, - profit_determination => { type => 'text' }, - language_id => { type => 'integer' }, + inventory_accno_id => { type => 'integer' }, + income_accno_id => { type => 'integer' }, + expense_accno_id => { type => 'integer' }, + fxgain_accno_id => { type => 'integer' }, + fxloss_accno_id => { type => 'integer' }, + invnumber => { type => 'text' }, + sonumber => { type => 'text' }, + weightunit => { type => 'varchar', length => 5 }, + businessnumber => { type => 'text' }, + version => { type => 'varchar', length => 8 }, + curr => { type => 'text' }, + closedto => { type => 'date' }, + revtrans => { type => 'boolean', default => 'false' }, + ponumber => { type => 'text' }, + sqnumber => { type => 'text' }, + rfqnumber => { type => 'text' }, + customernumber => { type => 'text' }, + vendornumber => { type => 'text' }, + audittrail => { type => 'boolean', default => 'false' }, + articlenumber => { type => 'text' }, + servicenumber => { type => 'text' }, + coa => { type => 'text' }, + itime => { type => 'timestamp', default => 'now()' }, + mtime => { type => 'timestamp' }, + rmanumber => { type => 'text' }, + cnnumber => { type => 'text' }, + accounting_method => { type => 'text' }, + inventory_system => { type => 'text' }, + profit_determination => { type => 'text' }, + dunning_ar_amount_fee => { type => 'integer' }, + dunning_ar_amount_interest => { type => 'integer' }, + dunning_ar => { type => 'integer' }, + pdonumber => { type => 'text' }, + sdonumber => { type => 'text' }, + ar_paid_accno_id => { type => 'integer' }, + id => { type => 'serial', not_null => 1 }, + language_id => { type => 'integer' }, + payments_changeable => { type => 'integer', default => '0', not_null => 1 }, + show_bestbefore => { type => 'boolean', default => 'false' }, + datev_check_on_sales_invoice => { type => 'boolean', default => 'true' }, + datev_check_on_purchase_invoice => { type => 'boolean', default => 'true' }, + datev_check_on_ar_transaction => { type => 'boolean', default => 'true' }, + datev_check_on_ap_transaction => { type => 'boolean', default => 'true' }, + datev_check_on_gl_transaction => { type => 'boolean', default => 'true' }, + is_changeable => { type => 'integer', default => 2, not_null => 1 }, + ir_changeable => { type => 'integer', default => 2, not_null => 1 }, + ar_changeable => { type => 'integer', default => 2, not_null => 1 }, + ap_changeable => { type => 'integer', default => 2, not_null => 1 }, + gl_changeable => { type => 'integer', default => 2, not_null => 1 }, + is_show_mark_as_paid => { type => 'boolean', default => 'true' }, + ir_show_mark_as_paid => { type => 'boolean', default => 'true' }, + ar_show_mark_as_paid => { type => 'boolean', default => 'true' }, + ap_show_mark_as_paid => { type => 'boolean', default => 'true' }, + sales_order_show_delete => { type => 'boolean', default => 'true' }, + purchase_order_show_delete => { type => 'boolean', default => 'true' }, + sales_delivery_order_show_delete => { type => 'boolean', default => 'true' }, + purchase_delivery_order_show_delete => { type => 'boolean', default => 'true' }, ], primary_key_columns => [ 'id' ], diff --git a/SL/DN.pm b/SL/DN.pm index 94e5b7708..46749ab37 100644 --- a/SL/DN.pm +++ b/SL/DN.pm @@ -368,6 +368,7 @@ sub send_email { my $template = SL::Template::create(type => 'PlainText', form => $form, myconfig => $myconfig); my $mail = Mailer->new(); + $mail->{charset} = $::lx_office_conf{system}->{dbcharset} || Common::DEFAULT_CHARSET; $mail->{from} = $myconfig->{email}; $mail->{to} = $ref->{recipient}; $mail->{subject} = $template->parse_block($ref->{email_subject}); diff --git a/SL/Form.pm b/SL/Form.pm index c14024f95..ce887c347 100644 --- a/SL/Form.pm +++ b/SL/Form.pm @@ -634,11 +634,9 @@ sub _prepare_html_template { $additional_params->{"conf_latex_templates"} = $::lx_office_conf{print_templates}->{latex}; $additional_params->{"conf_opendocument_templates"} = $::lx_office_conf{print_templates}->{opendocument}; $additional_params->{"conf_vertreter"} = $::lx_office_conf{features}->{vertreter}; - $additional_params->{"conf_show_best_before"} = $::lx_office_conf{features}->{show_best_before}; $additional_params->{"conf_parts_image_css"} = $::lx_office_conf{features}->{parts_image_css}; $additional_params->{"conf_parts_listing_images"} = $::lx_office_conf{features}->{parts_listing_images}; $additional_params->{"conf_parts_show_image"} = $::lx_office_conf{features}->{parts_show_image}; - $additional_params->{"conf_payments_changeable"} = $::lx_office_conf{features}->{payments_changeable}; $additional_params->{"INSTANCE_CONF"} = $::instance_conf; if (my $debug_options = $::lx_office_conf{debug}{options}) { diff --git a/SL/GL.pm b/SL/GL.pm index cdd9d406f..c9fcd9c47 100644 --- a/SL/GL.pm +++ b/SL/GL.pm @@ -186,7 +186,7 @@ sub post_transaction { } # safety check datev export - if ($::lx_office_conf{datev_check}{check_on_gl_transaction}) { + if ($::instance_conf->get_datev_check_on_gl_transaction) { my $transdate = $::form->{transdate} ? DateTime->from_lxoffice($::form->{transdate}) : undef; $transdate ||= DateTime->today; diff --git a/SL/IR.pm b/SL/IR.pm index 444dffceb..04e071e27 100644 --- a/SL/IR.pm +++ b/SL/IR.pm @@ -44,6 +44,7 @@ use SL::DO; use SL::GenericTranslations; use SL::IO; use SL::MoreCommon; +use SL::DB::Default; use List::Util qw(min); use strict; @@ -502,7 +503,7 @@ sub post_invoice { for my $i (1 .. $form->{paidaccounts}) { if ($form->{"acc_trans_id_$i"} && $payments_only - && ($::lx_office_conf{features}->{payments_changeable} == 0)) { + && (SL::DB::Default->get->payments_changeable == 0)) { next; } @@ -685,7 +686,7 @@ sub post_invoice { 'table' => 'ap',); # safety check datev export - if ($::lx_office_conf{datev_check}{check_on_purchase_invoice}) { + if ($::instance_conf->get_datev_check_on_purchase_invoice) { my $transdate = $::form->{invdate} ? DateTime->from_lxoffice($::form->{invdate}) : undef; $transdate ||= DateTime->today; @@ -1437,7 +1438,7 @@ sub post_payment { $old_form = save_form(); # Delete all entries in acc_trans from prior payments. - if ($::lx_office_conf{features}->{payments_changeable} != 0) { + if (SL::DB::Default->get->payments_changeable != 0) { $self->_delete_payments($form, $dbh); } diff --git a/SL/IS.pm b/SL/IS.pm index 266e05299..db18d5a43 100644 --- a/SL/IS.pm +++ b/SL/IS.pm @@ -48,6 +48,7 @@ use SL::MoreCommon; use SL::IC; use SL::IO; use SL::TransNumber; +use SL::DB::Default; use Data::Dumper; use strict; @@ -886,7 +887,7 @@ sub post_invoice { if ($form->{"acc_trans_id_$i"} && $payments_only - && ($::lx_office_conf{features}->{payments_changeable} == 0)) { + && (SL::DB::Default->get->payments_changeable == 0)) { next; } @@ -1076,7 +1077,7 @@ sub post_invoice { 'table' => 'ar',); # safety check datev export - if ($::lx_office_conf{datev_check}{check_on_sales_invoice}) { + if ($::instance_conf->get_datev_check_on_sales_invoice) { my $transdate = $::form->{invdate} ? DateTime->from_lxoffice($::form->{invdate}) : undef; $transdate ||= DateTime->today; @@ -1157,7 +1158,7 @@ sub post_payment { $old_form = save_form(); # Delete all entries in acc_trans from prior payments. - if ($::lx_office_conf{features}->{payments_changeable} != 0) { + if (SL::DB::Default->get->payments_changeable != 0) { $self->_delete_payments($form, $dbh); } diff --git a/SL/InstallationCheck.pm b/SL/InstallationCheck.pm index 451c41831..37f276c80 100644 --- a/SL/InstallationCheck.pm +++ b/SL/InstallationCheck.pm @@ -17,6 +17,7 @@ BEGIN { { name => "DBI", version => '1.50', url => "http://search.cpan.org/~timb/", debian => 'libdbi-perl' }, { name => "DBD::Pg", version => '1.49', url => "http://search.cpan.org/~dbdpg/", debian => 'libdbd-pg-perl' }, { name => "Email::Address", url => "http://search.cpan.org/~rjbs/", debian => 'libemail-address-perl' }, + { name => "Email::MIME", url => "http://search.cpan.org/~rjbs/", debian => 'libemail-mime-perl' }, { name => "FCGI", version => '0.72', url => "http://search.cpan.org/~mstrout/", debian => 'libfcgi-perl' }, { name => "JSON", url => "http://search.cpan.org/~makamaka", debian => 'libjson-perl' }, { name => "List::MoreUtils", version => '0.21', url => "http://search.cpan.org/~vparseval/", debian => 'liblist-moreutils-perl' }, @@ -41,7 +42,7 @@ BEGIN { { name => "Net::LDAP", url => "http://search.cpan.org/~gbarr/", debian => 'libnet-ldap-perl' }, # Net::SMTP is core since 5.7.3 { name => "Net::SMTP::SSL", version => '1.01', url => "http://search.cpan.org/~cwest/", debian => 'libnet-smtp-ssl-perl' }, - { name => "Net::SMTP::TLS", version => '0.12', url => "http://search.cpan.org/~awestholm/", debian => 'libnet-smtp-tls-perl' }, + { name => "Net::SSLGlue", version => '1.01', url => "http://search.cpan.org/~sullr/", debian => 'libnet-sslglue-perl' }, ); @developer_modules = ( diff --git a/SL/InstanceConfiguration.pm b/SL/InstanceConfiguration.pm index 24fd3be28..ac14b0ae0 100644 --- a/SL/InstanceConfiguration.pm +++ b/SL/InstanceConfiguration.pm @@ -49,6 +49,101 @@ sub get_profit_determination { return $self->{data}->{profit_determination}; } +sub get_is_changeable { + my ($self) = @_; + return $self->{data}->{is_changeable}; +} + +sub get_ir_changeable { + my ($self) = @_; + return $self->{data}->{ir_changeable}; +} + +sub get_ar_changeable { + my ($self) = @_; + return $self->{data}->{ar_changeable}; +} + +sub get_ap_changeable { + my ($self) = @_; + return $self->{data}->{ap_changeable}; +} + +sub get_gl_changeable { + my ($self) = @_; + return $self->{data}->{gl_changeable}; +} + +sub get_datev_check_on_sales_invoice { + my ($self) = @_; + return $self->{data}->{datev_check_on_sales_invoice}; +} + +sub get_datev_check_on_purchase_invoice { + my ($self) = @_; + return $self->{data}->{datev_check_on_purchase_invoice}; +} + +sub get_datev_check_on_ar_transaction { + my ($self) = @_; + return $self->{data}->{datev_check_on_ar_transaction}; +} + +sub get_datev_check_on_ap_transaction { + my ($self) = @_; + return $self->{data}->{datev_check_on_ap_transaction}; +} + +sub get_datev_check_on_gl_transaction { + my ($self) = @_; + return $self->{data}->{datev_check_on_gl_transaction}; +} + +sub get_show_bestbefore { + my ($self) = @_; + return $self->{data}->{show_bestbefore}; +} + +sub get_is_show_mark_as_paid { + my ($self) = @_; + return $self->{data}->{is_show_mark_as_paid}; +} + +sub get_ir_show_mark_as_paid { + my ($self) = @_; + return $self->{data}->{ir_show_mark_as_paid}; +} + +sub get_ar_show_mark_as_paid { + my ($self) = @_; + return $self->{data}->{ar_show_mark_as_paid}; +} + +sub get_ap_show_mark_as_paid { + my ($self) = @_; + return $self->{data}->{ap_show_mark_as_paid}; +} + +sub get_sales_order_show_delete { + my ($self) = @_; + return $self->{data}->{sales_order_show_delete}; +} + +sub get_purchase_order_show_delete { + my ($self) = @_; + return $self->{data}->{purchase_order_show_delete}; +} + +sub get_sales_delivery_order_show_delete { + my ($self) = @_; + return $self->{data}->{sales_delivery_order_show_delete}; +} + +sub get_purchase_delivery_order_show_delete { + my ($self) = @_; + return $self->{data}->{purchase_delivery_order_show_delete}; +} + 1; __END__ @@ -101,6 +196,66 @@ Returns the default inventory system, perpetual or periodic Returns the default profit determination method, balance or income + +=item C + +=item C + +=item C + +=item C + +=item C + +Returns if and when these record types are changeable or deleteable after +posting. 0 means never, 1 means always and 2 means on the same day. + +=item C + +Returns true if datev check should be performed on sales invoices + +=item C + +Returns true if datev check should be performed on purchase invoices + +=item C + +Returns true if datev check should be performed on ar transactions + +=item C + +Returns true if datev check should be performed on ap transactions + +=item C + +Returns true if datev check should be performed on gl transactions + +=item C + +Returns the default behavior for showing best before date, true or false + +=item C + +=item C + +=item C + +=item C + +Returns the default behavior for showing the mark as paid button for the +corresponding record type (true or false). + +=item C + +=item C + +=item C + +=item C + +Returns the default behavior for showing the delete button for the +corresponding record type (true or false). + =back =head1 BUGS diff --git a/SL/Mailer.pm b/SL/Mailer.pm index b04af08dd..2857e1c75 100644 --- a/SL/Mailer.pm +++ b/SL/Mailer.pm @@ -5,14 +5,6 @@ # Web http://www.lx-office.org # #===================================================================== -# SQL-Ledger Accounting -# Copyright (C) 2001 -# -# Author: Dieter Simader -# Email: dsimader@sql-ledger.org -# Web: http://www.sql-ledger.org -# -# Contributors: # # This program is free software; you can redistribute it and/or modify # it under the terms of the GNU General Public License as published by @@ -31,7 +23,8 @@ package Mailer; use Email::Address; -use Encode; +use Email::MIME::Creator; +use File::Slurp; use SL::Common; use SL::MIME; @@ -42,13 +35,9 @@ use strict; my $num_sent = 0; sub new { - $main::lxdebug->enter_sub(); - my ($type, %params) = @_; my $self = { %params }; - $main::lxdebug->leave_sub(); - bless $self, $type; } @@ -61,232 +50,161 @@ sub _create_driver { myconfig => \%::myconfig, ); - my $cfg = $::lx_office_conf{mail_delivery}; - if (($cfg->{method} || 'smtp') ne 'smtp') { - require SL::Mailer::Sendmail; - return SL::Mailer::Sendmail->new(%params); - } else { - require SL::Mailer::SMTP; - return SL::Mailer::SMTP->new(%params); - } -} - -sub mime_quote_text { - $main::lxdebug->enter_sub(); - - my ($self, $text, $chars_left) = @_; - - my $q_start = "=?$self->{charset}?Q?"; - my $l_start = length($q_start); + my $module = ($::lx_office_conf{mail_delivery}->{method} || 'smtp') ne 'smtp' ? 'SL::Mailer::Sendmail' : 'SL::Mailer::SMTP'; + eval "require $module" or return undef; - my $new_text = "$q_start"; - $chars_left -= $l_start if (defined $chars_left); - - for (my $i = 0; $i < length($text); $i++) { - my $char = ord(substr($text, $i, 1)); - - if (($char < 32) || ($char > 127) || ($char == ord('?')) || ($char == ord('_'))) { - if ((defined $chars_left) && ($chars_left < 5)) { - $new_text .= "?=\n $q_start"; - $chars_left = 75 - $l_start; - } - - $new_text .= sprintf("=%02X", $char); - $chars_left -= 3 if (defined $chars_left); - - } else { - $char = ord('_') if ($char == ord(' ')); - if ((defined $chars_left) && ($chars_left < 5)) { - $new_text .= "?=\n $q_start"; - $chars_left = 75 - $l_start; - } - - $new_text .= chr($char); - $chars_left-- if (defined $chars_left); - } - } - - $new_text .= "?="; - - $main::lxdebug->leave_sub(); - - return $new_text; + return $module->new(%params); } -sub send { - $main::lxdebug->enter_sub(); - +sub _cleanup_addresses { my ($self) = @_; - local (*IN); - - $num_sent++; - my $boundary = time() . "-$$-${num_sent}"; - $boundary = "LxOffice-$self->{version}-$boundary"; - my $domain = $self->recode($self->{from}); - $domain =~ s/(.*?\@|>)//g; - my $msgid = "$boundary\@$domain"; - - my $form = $main::form; - my $myconfig = \%main::myconfig; - - my $driver = eval { $self->_create_driver }; - if (!$driver) { - $main::lxdebug->leave_sub(); - return "send email : $@"; - } - - $self->{charset} ||= Common::DEFAULT_CHARSET; - $self->{contenttype} ||= "text/plain"; - foreach my $item (qw(to cc bcc)) { - next unless ($self->{$item}); - $self->{$item} = $self->recode($self->{$item}); + next unless $self->{$item}; + $self->{$item} =~ s/\</{$item} =~ s/\$<\$/{$item} =~ s/\>/>/g; $self->{$item} =~ s/\$>\$/>/g; } +} - $self->{from} = $self->recode($self->{from}); +sub _create_message_id { + my ($self) = @_; + + $num_sent += 1; + my $domain = $self->{from}; + $domain =~ s/.*\@//; + $domain =~ s/>.*//; + + return "kivitendo-$self->{version}-" . time() . "-${$}-${num_sent}\@$domain"; +} + +sub _create_address_headers { + my ($self) = @_; + + $self->{addresses} = {}; - my %addresses; - my $headers = ''; foreach my $item (qw(from to cc bcc)) { - $addresses{$item} = []; - next unless ($self->{$item}); + $self->{addresses}->{$item} = []; + next if !$self->{$item} || $self->{driver}->keep_from_header($item); - my (@addr_objects) = Email::Address->parse($self->{$item}); - next unless (scalar @addr_objects); + my @header_addresses; - foreach my $addr_obj (@addr_objects) { - push @{ $addresses{$item} }, $addr_obj->address; + foreach my $addr_obj (Email::Address->parse($self->{$item})) { + push @{ $self->{addresses}->{$item} }, $addr_obj->address; my $phrase = $addr_obj->phrase(); if ($phrase) { $phrase =~ s/^\"//; $phrase =~ s/\"$//; - $addr_obj->phrase($self->mime_quote_text($phrase)); + $addr_obj->phrase($phrase); } - $headers .= sprintf("%s: %s\n", ucfirst($item), $addr_obj->format()) unless $driver->keep_from_header($item); - } - } - - $headers .= sprintf("Subject: %s\n", $self->mime_quote_text($self->recode($self->{subject}), 60)); - - $driver->start_mail(from => $self->{from}, to => [ map { @{ $addresses{$_} } } qw(to cc bcc) ]); - - $driver->print(qq|${headers}Message-ID: <$msgid> -X-Mailer: Lx-Office $self->{version} -MIME-Version: 1.0 -|); - - if ($self->{attachments}) { - $driver->print(qq|Content-Type: multipart/mixed; boundary="$boundary"\n\n|); - if ($self->{message}) { - $driver->print(qq|--${boundary} -Content-Type: $self->{contenttype}; charset="$self->{charset}" - -| . $self->recode($self->{message}) . qq| - -|); + push @header_addresses, $addr_obj->format; } - foreach my $attachment (@{ $self->{attachments} }) { - - my $filename; - - if (ref($attachment) eq "HASH") { - $filename = $attachment->{"name"}; - $attachment = $attachment->{"filename"}; - } else { - $filename = $attachment; - # strip path - $filename =~ s/(.*\/|\Q$self->{fileid}\E)//g; - } - - my $application = ($attachment =~ /(^\w+$)|\.(html|text|txt|sql)$/) ? "text" : "application"; - my $content_type = SL::MIME->mime_type_from_ext($filename); - $content_type = "${application}/$self->{format}" if (!$content_type && $self->{format}); - $content_type ||= 'application/octet-stream'; - - open(IN, $attachment); - if ($?) { - $main::lxdebug->leave_sub(); - return "$attachment : $!"; - } - - # only set charset for attachements of type text. every other type should not have this field - # refer to bug 883 for detailed information - my $attachment_charset; - if (lc $application eq 'text' && $self->{charset}) { - $attachment_charset = qq|; charset="$self->{charset}" |; - } + push @{ $self->{headers} }, ( ucfirst($item) => join(', ', @header_addresses) ) if @header_addresses; + } +} - $driver->print(qq|--${boundary} -Content-Type: ${content_type}; name="$filename"$attachment_charset -Content-Transfer-Encoding: BASE64 -Content-Disposition: attachment; filename="$filename"\n\n|); +sub _create_attachment_part { + my ($self, $attachment) = @_; - my $msg = ""; - while () { - ; - $msg .= $_; - } - $driver->print(encode_base64($msg)); + my $source_file_name; - close(IN); + my %attributes = ( + disposition => 'attachment', + encoding => 'base64', + ); - } - $driver->print(qq|--${boundary}--\n|); + if (ref($attachment) eq "HASH") { + $attributes{filename} = $attachment->{name}; + $source_file_name = $attachment->{filename}; } else { - $driver->print(qq|Content-Type: $self->{contenttype}; charset="$self->{charset}" - -| . $self->recode($self->{message}) . qq| -|); + # strip path + $attributes{filename} = $attachment; + $attributes{filename} =~ s:.*\Q$self->{fileid}\E:: if $self->{fileid}; + $attributes{filename} =~ s:.*/::g; + $source_file_name = $attachment; } - $driver->send; + my $attachment_content = eval { read_file($source_file_name) }; + return undef if !defined $attachment_content; - $main::lxdebug->leave_sub(); + my $application = ($attachment =~ /(^\w+$)|\.(html|text|txt|sql)$/) ? 'text' : 'application'; + $attributes{content_type} = SL::MIME->mime_type_from_ext($attributes{filename}); + $attributes{content_type} ||= "${application}/$self->{format}" if $self->{format}; + $attributes{content_type} ||= 'application/octet-stream'; + $attributes{charset} = $self->{charset} if lc $application eq 'text' && $self->{charset}; - return ""; + return Email::MIME->create( + attributes => \%attributes, + body => $attachment_content, + ); } -sub encode_base64 ($;$) { - $main::lxdebug->enter_sub(); +sub _create_message { + my ($self) = @_; - # this code is from the MIME-Base64-2.12 package - # Copyright 1995-1999,2001 Gisle Aas + my @parts; + + if ($self->{message}) { + push @parts, Email::MIME->create( + attributes => { + content_type => $self->{contenttype}, + charset => $self->{charset}, + encoding => 'quoted-printable', + }, + body_str => $self->{message}, + ); + + push @{ $self->{headers} }, ( + 'Content-Type' => qq|$self->{contenttype}; charset="$self->{charset}"|, + ); + } - my $res = ""; - my $eol = $_[1]; - $eol = "\n" unless defined $eol; - pos($_[0]) = 0; # ensure start at the beginning + push @parts, grep { $_ } map { $self->_create_attachment_part($_) } @{ $self->{attachments} || [] }; - $res = join '', map(pack('u', $_) =~ /^.(\S*)/, ($_[0] =~ /(.{1,45})/gs)); + return Email::MIME->create( + header_str => $self->{headers}, + parts => \@parts, + ); +} - $res =~ tr|` -_|AA-Za-z0-9+/|; # `# help emacs - # fix padding at the end - my $padding = (3 - length($_[0]) % 3) % 3; - $res =~ s/.{$padding}$/'=' x $padding/e if $padding; +sub send { + my ($self) = @_; - # break encoded string into lines of no more than 60 characters each - if (length $eol) { - $res =~ s/(.{1,60})/$1$eol/g; + # Create driver for delivery method (sendmail/SMTP) + $self->{driver} = eval { $self->_create_driver }; + if (!$self->{driver}) { + $::lxdebug->leave_sub(); + return "send email : $@"; } - $main::lxdebug->leave_sub(); + # Set defaults & headers + $self->{charset} ||= Common::DEFAULT_CHARSET; + $self->{contenttype} ||= "text/plain"; + $self->{headers} = [ + Subject => $self->{subject}, + 'Message-ID' => $self->_create_message_id, + 'X-Mailer' => "kivitendo $self->{version}", + ]; - return $res; -} + # Clean up To/Cc/Bcc address fields + $self->_cleanup_addresses; + $self->_create_address_headers; + + my $email = $self->_create_message; + + # $::lxdebug->message(0, "message: " . $email->as_string); + # return "boom"; -sub recode { - my $self = shift; - my $text = shift; + $self->{driver}->start_mail(from => $self->{from}, to => [ map { @{ $self->{addresses}->{$_} } } qw(to cc bcc) ]); + $self->{driver}->print($email->as_string); + $self->{driver}->send; - return $::locale->is_utf8 ? Encode::encode('utf-8-strict', $text) : $text; + return ''; } 1; diff --git a/SL/Mailer/SMTP.pm b/SL/Mailer/SMTP.pm index 831bd72b4..8012a04cd 100644 --- a/SL/Mailer/SMTP.pm +++ b/SL/Mailer/SMTP.pm @@ -9,33 +9,31 @@ use Rose::Object::MakeMethods::Generic scalar => [ qw(myconfig mailer form) ] ); +my %security_config = ( + none => { require_module => 'Net::SMTP', package => 'Net::SMTP', port => 25 }, + tls => { require_module => 'Net::SSLGlue::SMTP', package => 'Net::SMTP', port => 25 }, + ssl => { require_module => 'Net::SMTP::SSL', package => 'Net::SMTP::SSL', port => 465 }, +); + sub init { my ($self) = @_; Rose::Object::init(@_); my $cfg = $::lx_office_conf{mail_delivery} || {}; - $self->{security} = lc($cfg->{security} || 'none'); - - if ($self->{security} eq 'tls') { - require Net::SMTP::TLS; - my %params; - if ($cfg->{login}) { - $params{User} = $cfg->{user}; - $params{Password} = $cfg->{password}; - } - $self->{smtp} = Net::SMTP::TLS->new($cfg->{host} || 'localhost', Port => $cfg->{port} || 25, %params); - - } else { - my $module = $self->{security} eq 'ssl' ? 'Net::SMTP::SSL' : 'Net::SMTP'; - my $default_port = $self->{security} eq 'ssl' ? 465 : 25; - eval "require $module" or die $@; - - $self->{smtp} = $module->new($cfg->{host} || 'localhost', Port => $cfg->{port} || $default_port); - $self->{smtp}->auth($cfg->{user}, $cfg->{password}) if $cfg->{login}; - } + $self->{security} = exists $security_config{lc $cfg->{security}} ? lc $cfg->{security} : 'none'; + my $sec_cfg = $security_config{ $self->{security} }; + + eval "require $sec_cfg->{require_module}" or die "$@"; + $self->{smtp} = $sec_cfg->{package}->new($cfg->{host} || 'localhost', Port => $cfg->{port} || $sec_cfg->{port}); die unless $self->{smtp}; + + $self->{smtp}->starttls(SSL_verify_mode => 0) || die if $self->{security} eq 'tls'; + + return 1 unless $cfg->{login}; + + $self->{smtp}->auth($cfg->{user}, $cfg->{password}) or die; } sub start_mail { diff --git a/SL/Mailer/Sendmail.pm b/SL/Mailer/Sendmail.pm index 6b24ecdb5..ea1e63b8a 100644 --- a/SL/Mailer/Sendmail.pm +++ b/SL/Mailer/Sendmail.pm @@ -2,6 +2,7 @@ package SL::Mailer::Sendmail; use strict; +use Encode; use IO::File; use SL::Template; @@ -17,7 +18,7 @@ sub init { Rose::Object::init(@_); - my $email = $self->mailer->recode($self->myconfig->{email}); + my $email = $::locale->is_utf8 ? Encode::encode('utf-8', $self->myconfig->{email}) : $self->myconfig->{email}; $email =~ s/[^\w\.\-\+=@]//ig; my %temp_form = ( %{ $self->form }, myconfig_email => $email ); @@ -26,6 +27,7 @@ sub init { $sendmail = $template->parse_block($sendmail); $self->{sendmail} = IO::File->new("|$sendmail") || die "sendmail($sendmail): $!"; + $self->{sendmail}->binmode(':utf8') if $::locale->is_utf8; } sub start_mail { diff --git a/SL/System/Process.pm b/SL/System/Process.pm index 0bddfd6b3..482e6d33f 100644 --- a/SL/System/Process.pm +++ b/SL/System/Process.pm @@ -35,7 +35,7 @@ SL::System::Process - assorted system-relevant functions =head1 SYNOPSIS - # Get base path to Kivitendo scripts + # Get base path to kivitendo scripts my $path = SL::System::Process->exe_dir; =head1 FUNCTIONS @@ -44,7 +44,7 @@ SL::System::Process - assorted system-relevant functions =item C -Returns the absolute path to the directory the Kivitendo executables +Returns the absolute path to the directory the kivitendo executables (C etc.) and modules (sub-directory C etc.) are located in. diff --git a/bin/mozilla/ap.pl b/bin/mozilla/ap.pl index 8c55a3d9c..732eaed5e 100644 --- a/bin/mozilla/ap.pl +++ b/bin/mozilla/ap.pl @@ -40,6 +40,7 @@ use SL::IR; use SL::IS; use SL::PE; use SL::ReportGenerator; +use SL::DB::Default; require "bin/mozilla/arap.pl"; require "bin/mozilla/common.pl"; @@ -238,7 +239,9 @@ sub form_header { } my $readonly = ($form->{id}) ? "readonly" : ""; - $form->{radier} = ($form->current_date(\%myconfig) eq $form->{gldate}) ? 1 : 0; + $form->{radier} = ($::instance_conf->get_ap_changeable == 2) + ? ($form->current_date(\%myconfig) eq $form->{gldate}) + : ($::instance_conf->get_ap_changeable == 1); $readonly = ($form->{radier}) ? "" : $readonly; $form->{forex} = $form->check_exchangerate( \%myconfig, $form->{currency}, $form->{transdate}, 'sell'); @@ -693,11 +696,11 @@ $jsscript print qq|{"acc_trans_id_$i"}>\n|; print qq|{"gldate_$i"}>\n|; my $changeable = 1; - if ($::lx_office_conf{features}->{payments_changeable} == 0) { + if (SL::DB::Default->get->payments_changeable == 0) { # never $changeable = ($form->{"acc_trans_id_$i"})? 0 : 1; } - if ($::lx_office_conf{features}->{payments_changeable} == 2) { + if (SL::DB::Default->get->payments_changeable == 2) { # on the same day $changeable = (($form->{"gldate_$i"} eq '') || $form->current_date(\%myconfig) eq $form->{"gldate_$i"}); } @@ -852,10 +855,10 @@ sub form_footer { $::form->header; print $::form->parse_html_template('ap/form_footer', { - num_due => $num_due, - num_follow_ups => $num_follow_ups, - show_post_draft => ($transdate > $closedto) && !$::form->{id}, - show_storno => $storno, + num_due => $num_due, + num_follow_ups => $num_follow_ups, + show_post_draft => ($transdate > $closedto) && !$::form->{id}, + show_storno => $storno, }); $::lxdebug->leave_sub; diff --git a/bin/mozilla/ar.pl b/bin/mozilla/ar.pl index f164997af..be080ea6a 100644 --- a/bin/mozilla/ar.pl +++ b/bin/mozilla/ar.pl @@ -38,6 +38,7 @@ use SL::AR; use SL::FU; use SL::IS; use SL::PE; +use SL::DB::Default; use SL::ReportGenerator; require "bin/mozilla/arap.pl"; @@ -251,7 +252,9 @@ sub form_header { #/show history button js $readonly = ($form->{id}) ? "readonly" : ""; - $form->{radier} = ($form->current_date(\%myconfig) eq $form->{gldate}) ? 1 : 0; + $form->{radier} = ($::instance_conf->get_ar_changeable == 2) + ? ($form->current_date(\%myconfig) eq $form->{gldate}) + : ($::instance_conf->get_ar_changeable == 1); $readonly = ($form->{radier}) ? "" : $readonly; # set option selected @@ -421,8 +424,8 @@ sub form_header { $payment->{changeable} = - $::lx_office_conf{features}->{payments_changeable} == 0 ? !$payment->{acc_trans_id} # never - : $::lx_office_conf{features}->{payments_changeable} == 2 ? $payment->{gldate} eq '' || $payment->{gldate} eq $now + SL::DB::Default->get->payments_changeable == 0 ? !$payment->{acc_trans_id} # never + : SL::DB::Default->get->payments_changeable == 2 ? $payment->{gldate} eq '' || $payment->{gldate} eq $now : 1; push @payments, $payment; @@ -530,7 +533,7 @@ $follow_ups_block } # /button for saving history # mark_as_paid button - if($form->{id} ne "") { + if(($form->{id} ne "") && $::instance_conf->get_ar_show_mark_as_paid) { print qq||; } diff --git a/bin/mozilla/do.pl b/bin/mozilla/do.pl index b58cd7190..570c7c358 100644 --- a/bin/mozilla/do.pl +++ b/bin/mozilla/do.pl @@ -1444,7 +1444,7 @@ sub transfer_out { my $pinfo = $part_info_map{$request->{parts_id}}; my $binfo = $bin_info_map{$request->{bin_id}}; - if ($::lx_office_conf{features}->{show_best_before}) { + if ($::instance_conf->get_show_bestbefore) { push @{ $form->{ERRORS} }, $locale->text("There is not enough available of '#1' at warehouse '#2', bin '#3', #4, #5, for the transfer of #6.", $pinfo->{description}, $binfo->{warehouse_description}, diff --git a/bin/mozilla/gl.pl b/bin/mozilla/gl.pl index a46cad00c..719f22209 100644 --- a/bin/mozilla/gl.pl +++ b/bin/mozilla/gl.pl @@ -903,7 +903,9 @@ sub form_footer { $follow_ups_due = sum map { $_->{due} * 1 } @{ $follow_ups || [] }; } - my $radieren = $::form->current_date(\%::myconfig) eq $::form->{gldate}; + my $radieren = ($::instance_conf->get_gl_changeable == 2) + ? ($::form->current_date(\%::myconfig) eq $::form->{gldate}) + : ($::instance_conf->get_gl_changeable == 1); print $::form->parse_html_template('gl/form_footer', { radieren => $radieren, diff --git a/bin/mozilla/ir.pl b/bin/mozilla/ir.pl index 0a468615e..554d2fd4f 100644 --- a/bin/mozilla/ir.pl +++ b/bin/mozilla/ir.pl @@ -35,6 +35,7 @@ use SL::FU; use SL::IR; use SL::IS; use SL::PE; +use SL::DB::Default; use List::Util qw(max sum); require "bin/mozilla/io.pl"; @@ -415,10 +416,10 @@ sub form_footer { for my $i (1 .. $form->{paidaccounts}) { $form->{"changeable_$i"} = 1; - if ($::lx_office_conf{features}->{payments_changeable} == 0) { + if (SL::DB::Default->get->payments_changeable == 0) { # never $form->{"changeable_$i"} = ($form->{"acc_trans_id_$i"})? 0 : 1; - } elsif ($::lx_office_conf{features}->{payments_changeable} == 2) { + } elsif (SL::DB::Default->get->payments_changeable == 2) { # on the same day $form->{"changeable_$i"} = (($form->{"gldate_$i"} eq '') || ($form->current_date(\%myconfig) eq $form->{"gldate_$i"})); @@ -439,7 +440,9 @@ sub form_footer { totalpaid => $totalpaid, paid_missing => $form->{invtotal} - $totalpaid, show_storno => $form->{id} && !$form->{storno} && !IS->has_storno(\%myconfig, $form, "ap") && !$totalpaid, - show_delete => ($form->current_date(\%myconfig) eq $form->{gldate}), + show_delete => ($::instance_conf->get_ir_changeable == 2) + ? ($form->current_date(\%myconfig) eq $form->{gldate}) + : ($::instance_conf->get_ir_changeable == 1), }); ##print $form->parse_html_template('ir/_payments'); # parser ##print $form->parse_html_template('webdav/_list'); # parser diff --git a/bin/mozilla/is.pl b/bin/mozilla/is.pl index d5bd22946..14c242000 100644 --- a/bin/mozilla/is.pl +++ b/bin/mozilla/is.pl @@ -35,6 +35,7 @@ use SL::FU; use SL::IS; use SL::PE; use SL::OE; +use SL::DB::Default; use Data::Dumper; use List::Util qw(max sum); @@ -444,10 +445,10 @@ sub form_footer { for my $i (1 .. $form->{paidaccounts}) { $form->{"changeable_$i"} = 1; - if ($::lx_office_conf{features}->{payments_changeable} == 0) { + if (SL::DB::Default->get->payments_changeable == 0) { # never $form->{"changeable_$i"} = ($form->{"acc_trans_id_$i"})? 0 : 1; - } elsif ($::lx_office_conf{features}->{payments_changeable} == 2) { + } elsif (SL::DB::Default->get->payments_changeable == 2) { # on the same day $form->{"changeable_$i"} = (($form->{"gldate_$i"} eq '') || ($form->current_date(\%myconfig) eq $form->{"gldate_$i"})); @@ -471,7 +472,9 @@ sub form_footer { paid_missing => $form->{invtotal} - $totalpaid, print_options => print_options(inline => 1), show_storno => $form->{id} && !$form->{storno} && !IS->has_storno(\%myconfig, $form, "ar") && !$totalpaid, - show_delete => ($form->current_date(\%myconfig) eq $form->{gldate}), + show_delete => ($::instance_conf->get_is_changeable == 2) + ? ($form->current_date(\%myconfig) eq $form->{gldate}) + : ($::instance_conf->get_is_changeable == 1), }); ##print $form->parse_html_template('is/_payments'); # parser ##print $form->parse_html_template('webdav/_list'); # parser diff --git a/bin/mozilla/wh.pl b/bin/mozilla/wh.pl index 9d387f02e..0315bb9dc 100644 --- a/bin/mozilla/wh.pl +++ b/bin/mozilla/wh.pl @@ -438,7 +438,7 @@ sub create_assembly { $form->error($locale->text('The warehouse or the bin is missing.')); } - if (!$::lx_office_conf{features}->{show_best_before}) { + if (!$::instance_conf->get_show_bestbefore) { $form->{bestbefore} = ''; } diff --git a/config/kivitendo.conf.default b/config/kivitendo.conf.default index 5d6524bf8..96a7d4290 100644 --- a/config/kivitendo.conf.default +++ b/config/kivitendo.conf.default @@ -74,17 +74,6 @@ dbcharset = UTF-8 webdav = 0 vertreter = 0 -# Show fields used for the best before date -# ATTENTION! If you enabled this feature you can not simply turn it off again -# without taking care that best_before fields are emptied in the database. -# This can be done with the following query: -# -# UPDATE inventory SET bestbefore = NULL; -# -# Any stock contents containing a best before date will be impossible to stock -# out otherwise. -show_best_before = 0 - ## Pictures for parts # Show the picture in the part form parts_show_image = 1 @@ -93,9 +82,6 @@ parts_image_css = border:0;float:left;max-width:250px;margin-top:20px:margin-rig # Show the picture in the results when you search for parts parts_listing_images = 0 -# Should payments be changeable after posting (0 = never; 1 = every time; 2 = on the same day) -payments_changeable = 0 - [paths] # path to temporary files (must be writeable by the web server) userspath = users @@ -115,13 +101,15 @@ memberfile = users/members method = smtp # Location of sendmail for 'method = sendmail' sendmail = /usr/sbin/sendmail -t<%if myconfig_email%> -f <%myconfig_email%><%end%> -# Settings for 'method = smtp'. +# Settings for 'method = smtp'. Only set 'port' if your SMTP server +# runs on a non-standard port (25 for 'security=none' or +# 'security=tls', 465 for 'security=ssl'). host = localhost -port = 25 +#port = 25 # Security can be 'tls', 'ssl' or 'none'. Unset equals 'none'. This # determines whether or not encryption is used and which kind. For -# 'tls' the module 'Net::SMTP::TLS' is required; for 'ssl' -# 'Net::SMTP::TLS' is required and 'none' only uses 'Net::SMTP'. +# 'tls' the module 'Net::SSLGlue' is required; for 'ssl' +# 'Net::SMTP::SSL' is required and 'none' only uses 'Net::SMTP'. security = none # Authentication is only used if 'login' is set. You should only use # that with 'tls' or 'ssl' encryption. @@ -210,27 +198,6 @@ email_subject = kivitendo self test report # template. currently txt and html templates are recognized and correctly mime send. email_template = templates/mail/self_test/status_mail.txt -[datev_check] -# it is possible to make a quick DATEV export everytime you post a record to ensure things -# work nicely with their data requirements. This will result in a slight overhead though -# you can enable this for each type of record independantly. - -# check when a sales invoice or a payment for a sales invoice is posted -check_on_sales_invoice = 1 -# check when a purchase invoice or a payment for a purchase invoice is posted -check_on_purchase_invoice = 1 -# check when an ar transaction is posted -check_on_ar_transaction = 1 -# check when an ap transaction is posted -check_on_ap_transaction = 1 -# check when a gl transaction is posted -check_on_gl_transaction = 1 - -# not implemented yet: -#check_on_cash_and_receipt = 0 -#check_on_dunning = 0 -#check_on_sepa_import = 0 - [console] # autologin to use if none is given login = diff --git a/doc/dokumentation.xml b/doc/dokumentation.xml index 787007405..8fe04d68a 100644 --- a/doc/dokumentation.xml +++ b/doc/dokumentation.xml @@ -43,7 +43,7 @@ - Ubuntu 10.04 LTS Lucid Lynx bis 12.04 Precise Pangolin + Ubuntu 10.04 LTS Lucid Lynx bis 12.10 Oneiric Ocelot @@ -75,87 +75,58 @@ nicht Bestandteil einer Standard-Perl-Installation sind: - - parent - + parent - - Archive::Zip - + Archive::Zip - - Config::Std - + Config::Std - - DateTime - + DateTime - - DBI - + DBI - - DBD::Pg - + DBD::Pg - - Email::Address - + Email::Address - - JSON - + Email::MIME - - List::MoreUtils - + JSON - - Params::Validate - + List::MoreUtils - - PDF::API2 - + Net::SMTP::SSL (optional, bei E-Mail-Versand über SSL; siehe Abschnitt "") - - Rose::Object - + Net::SSLGlue (optional, bei E-Mail-Versand über TLS; siehe Abschnitt "") - - Rose::DB - + Params::Validate - - Rose::DB::Object - + PDF::API2 - - Template - + Rose::Object - - Text::CSV_XS - + Rose::DB - - Text::Iconv - + Rose::DB::Object - - URI - + Template - - XML::Writer - + Text::CSV_XS - - YAML - + Text::Iconv + + URI + + XML::Writer + + YAML + Seit v2.7.0 sind die folgenden Pakete hinzugekommen: Email::MIME, Net::SMTP::SSL, + Net::SSLGlue. + Gegenüber Version 2.6.0 sind zu dieser Liste 2 Pakete hinzugekommen, URI und XML::Writer sind notwendig. Ohne startet kivitendo @@ -184,31 +155,27 @@ apt-get install apache2 postgresql libparent-perl libarchive-zip-perl \ libdatetime-perl libdbi-perl libdbd-pg-perl libpg-perl \ - libemail-address-perl liblist-moreutils-perl libpdf-api2-perl \ + libemail-address-perl libemail-mime-perl liblist-moreutils-perl libpdf-api2-perl \ librose-object-perl librose-db-perl librose-db-object-perl \ libtemplate-perl libtext-csv-xs-perl libtext-iconv-perl liburi-perl \ libxml-writer-perl libyaml-perl libconfig-std-perl \ - libparams-validate-perl libjson-perl libclass-accessor-perl + libparams-validate-perl libjson-perl libclass-accessor-perl \ + libnet-sslglue-perl libnet-smtp-ssl-perl Für Fedora Core benötigen Sie diese Pakete: yum install httpd postgresql-server perl-parent perl-DateTime \ - perl-DBI perl-DBD-Pg perl-Email-Address perl-List-MoreUtils \ + perl-DBI perl-DBD-Pg perl-Email-Address perl-Email-MIME perl-List-MoreUtils \ perl-PDF-API2 perl-Rose-Object perl-Rose-DB perl-Rose-DB-Object \ perl-Template-Toolkit perl-Text-CSV_XS perl-Text-Iconv perl-URI \ - perl-XML-Writer perl-YAML + perl-XML-Writer perl-YAML perl-Net-SSLGlue perl-Net-SMTP-SSL Für OpenSuSE benötigen Sie diese Pakete: zypper install apache2 postgresql-server perl-Archive-Zip \ - perl-DateTime perl-DBI perl-DBD-Pg perl-MailTools perl-List-MoreUtils \ + perl-DateTime perl-DBI perl-DBD-Pg perl-Email-MIME perl-MailTools perl-List-MoreUtils \ perl-PDF-API2 perl-Template-Toolkit perl-Text-CSV_XS perl-Text-Iconv \ - perl-URI perl-XML-Writer perl-YAML - - Bei openSuSE 11 ist parent bereits enthalten, - und braucht nicht nachinstalliert werden. Die - Rose::* Pakete sind derzeit nicht für SuSE gepackt, - und müssen anderweitig nachinstalliert werden. + perl-URI perl-XML-Writer perl-YAML perl-Net-SSLGlue perl-Net-SMTP-SSL kivitendo enthält ein Script, mit dem überprüft werden kann, ob alle benötigten Perl-Module installiert sind. Der Aufruf lautet wie @@ -303,57 +270,34 @@ tar xvzf kivitendo-erp-2.6.3.tgz entsprechend kommentiert sind: - - authentication - + authentication (siehe Abschnitt "" in diesem Kapitel) - - authentication/database - + authentication/database - - authentication/ldap - + authentication/ldap - - system - + system - - features - + features (siehe Kapitel "") - - paths - + paths - - applications - + applications - - environment - + environment - - print_templates - + mail_delivery (siehe Abschnitt ") - - task_server - + print_templates - - periodic_invoices - + task_server - - console - + periodic_invoices - - debug - + console + + debug Die üblicherweise wichtigsten Parameter, die am Anfang @@ -494,10 +438,7 @@ psql template1 anlegen. Ein Beispiel, wie Sie einen neuen Benutzer anlegen können: - Die Frage, ob der neue User Superuser sein soll, können Sie mit nein - beantworten, genauso ist die Berechtigung neue User (Roles) zu - generieren nicht nötig. - su - postgres + su - postgres createuser -d -P kivitendo exit @@ -613,10 +554,9 @@ Alias /kivitendo-erp/ /var/www/kiviteno-erp/ verwendet. - FCGI 0.69 und höher ist extrem strict in der Behandlung von - Unicode, und verweigert bestimmte Eingaben von kivitendo. Falls es - Probleme mit Umlauten in Ihrere Installation gibt, muss auf die - Vorgängerversion FCGI 0.68 ausgewichen werden. + FCGI-Versionen ab 0.69 und bis zu 0.71 inklusive sind extrem strict in der Behandlung von Unicode, und verweigern + bestimmte Eingaben von kivitendo. Falls es Probleme mit Umlauten in Ihrere Installation gibt, muss zwingend Version 0.68 oder + aber Version 0.72 und neuer eingesetzt werden. Mit CPAN lässt sie sich die Vorgängerversion wie folgt installieren: @@ -1277,6 +1217,91 @@ insserv kivitendo-task-server + + E-Mail-Versand aus kivitendo heraus + + kivitendo kann direkt aus dem Programm heraus E-Mails versenden, z.B. um ein Angebot direkt an einen Kunden zu + verschicken. Damit dies funktioniert, muss eingestellt werden, über welchen Server die E-Mails verschickt werden sollen. kivitendo + unterstützt dabei zwei Mechanismen: Versand über einen lokalen E-Mail-Server (z.B. mit Postfix oder + Exim, was auch die standardmäßig aktive Methode ist) sowie Versand über einen SMTP-Server (z.B. der des + eigenen Internet-Providers). + + Welche Methode und welcher Server verwendet werden, wird über die Konfigurationsdatei config/kivitendo.conf + festgelegt. Dort befinden sich alle Einstellungen zu diesem Thema im Abschnitt '[mail_delivery]'. + + + Versand über lokalen E-Mail-Server + + Diese Methode bietet sich an, wenn auf dem Server, auf dem kivitendo läuft, bereits ein funktionsfähiger E-Mail-Server wie + z.B. Postfix, Exim oder Sendmail läuft. + + Um diese Methode auszuwählen, muss der Konfigurationsparameter 'method = sendmail' gesetzt sein. Dies ist + gleichzeitig der Standardwert, falls er nicht verändert wird. + + Um zu kontrollieren, wie das Programm zum Einliefern gestartet wird, dient der Parameter 'sendmail = + ...'. Der Standardwert verweist auf das Programm /usr/bin/sendmail, das bei allen oben genannten + E-Mail-Serverprodukten für diesen Zweck funktionieren sollte. + + Die Konfiguration des E-Mail-Servers selber würde den Rahmen dieses sprengen. Hierfür sei auf die Dokumentation des + E-Mail-Servers verwiesen. + + + + Versand über einen SMTP-Server + + Diese Methode bietet sich an, wenn kein lokaler E-Mail-Server vorhanden oder zwar einer vorhanden, dieser aber nicht + konfiguriert ist. + + Um diese Methode auszuwählen, muss der Konfigurationsparameter 'method = smtp' gesetzt sein. Die folgenden + Parameter dienen dabei der weiteren Konfiguration: + + + + hostname + + Name oder IP-Adresse des SMTP-Servers. Standardwert: 'localhost' + + + + port + + Portnummer. Der Standardwert hängt von der verwendeten Verschlüsselungsmethode ab. Gilt 'security = + none' oder 'security = tls', so ist 25 die Standardportnummer. Für 'security = + ssl' ist 465 die Portnummer. Muss normalerweise nicht geändert werden. + + + + security + + Wahl der zu verwendenden Verschlüsselung der Verbindung mit dem Server. Standardwert ist + 'none', wodurch keine Verschlüsselung verwendet wird. Mit 'tls' wird TLS-Verschlüsselung + eingeschaltet, und mit 'ssl' wird Verschlüsselung via SSL eingeschaltet. Achtung: Für + 'tls' und 'ssl' werden zusätzliche Perl-Module benötigt (siehe unten). + + + + login und password + + Falls der E-Mail-Server eine Authentifizierung verlangt, so können mit diesen zwei Parametern der Benutzername + und das Passwort angegeben werden. Wird Authentifizierung verwendet, so sollte aus Sicherheitsgründen auch eine Form von + Verschlüsselung aktiviert werden. + + + + Wird Verschlüsselung über TLS oder SSL aktiviert, so werden zusätzliche Perl-Module benötigt. Diese sind: + + + TLS-Verschlüsselung: Modul Net::SSLGlue (Debian-Paketname + libnet-sslglue-perl, Fedora Core: perl-Net-SSLGlue, openSuSE: + perl-Net-SSLGlue + + SSL-Verschlüsselung: Modul Net::SMTP::SSL (Debian-Paketname + libnet-smtp-ssl-perl, Fedora Core: perl-Net-SMTP-SSL, openSuSE: + perl-Net-SMTP-SSL + + + + Drucken mit kivitendo @@ -5432,6 +5457,148 @@ filenames + + Die kivitendo-Test-Suite + + + Einführung + + kivitendo enthält eine Suite für automatisierte Tests. Sie basiert auf dem Standard-Perl-Modul Test::More. + + Die grundlegenden Fakten sind: + + + Alle Tests liegen im Unterverzeichnis t/. + + Ein Script (bzw. ein Test) in f/ enthält einen oder mehrere Testfälle. + + Alle Dateinamen von Tests enden auf .t. Es sind selbstständig ausführbare Perl-Scripte. + + Die Test-Suite besteht aus der Gesamtheit aller Tests, sprich aller Scripte in f/, deren + Dateiname auf .t endet. + + + + + Voraussetzungen + + Für die Ausführung werden neben den für kivitendo eh schon benötigten Module noch weitere Perl-Module benötigt. Diese sind: + + + Test::Deep (Debian-Paketname: libtest-deep-perl; Fedora Core: + perl-Test-Deep; openSuSE: perl-Test-Deep) + + + + + + Existierende Tests ausführen + + + Es gibt mehrere Möglichkeiten zum Ausführen der Tests: entweder, man lässt alle Tests auf einmal ausführen, oder man führt + gezielt einzelne Scripte aus. Für beide Fälle gibt es das Helferscript t/test.sh. + + Will man die komplette Test-Suite ausführen, so muss man einfach nur t/test.sh ohne weitere Parameter aus + dem kivitendo-Basisverzeichnis heraus ausführen. + + Um einzelne Test-Scripte auszuführen, übergibt man deren Namen an t/test.sh. Beispielsweise: + + t/test.sh t/form/format_amount.t t/background_job/known_jobs.t + + + + + + Bedeutung der verschiedenen Test-Scripte + + + Die Test-Suite umfasst Tests sowohl für Funktionen als auch für Programmierstil. Einige besonders zu erwähnende, weil auch + während der Entwicklung nützliche Tests sind: + + + t/001compile.t -- compiliert alle Quelldateien und bricht bei Fehlern sofort ab + t/002goodperl.t -- überprüft alle Perl-Dateien auf Anwesenheit von 'use strict'-Anweisungen + t/003safesys.t -- überprüft Aufrufe von system() und exec() auf Gültigkeit + t/005no_tabs.t -- überprüft, ob Dateien Tab-Zeichen enthalten + t/006spelling.t -- sucht nach häufigen Rechtschreibfehlern + t/011pod.t -- überprüft die Syntax von Dokumentation im POD-Format auf Gültigkeit + + + Weitere Test-Scripte überprüfen primär die Funktionsweise einzelner Funktionen und Module. + + + + + Neue Test-Scripte erstellen + + + Es wird sehr gern gesehen, wenn neue Funktionalität auch gleich mit einem Test-Script abgesichert wird. Auch bestehende + Funktion darf und soll ausdrücklich nachträglich mit Test-Scripten abgesichert werden. + + + + Ideen für neue Test-Scripte, die keine konkreten Funktionen testen + + + Ideen, die abgesehen von Funktions noch nicht umgesetzt wurden: + + + Überprüfung auf fehlende symbolische Links + Suche nach Nicht-ASCII-Zeichen in Perl-Code-Dateien (mit gewissen Einschränkungen wie das Erlauben von deutschen Umlauten) + Test auf DOS-Zeilenenden (\r\n anstelle von nur \n) + Überprüfung auf Leerzeichen am Ende von Zeilen + Test, ob alle zu übersetzenden Strings in locale/de/all vorhanden sind + Test, ob alle Webseiten-Templates in templates/webpages mit vom Perl-Modul Template compiliert werden können + + + + + + Konvention für Verzeichnis- und Dateinamen + + + Es gibt momentan eine wenige Richtlinien, wie Test-Scripte zu benennen sind. Bitte die folgenden Punkte als Richtlinie betrachten und ihnen soweit es geht folgen: + + + Die Dateiendung muss .t lauten. + + Namen sind englisch, komplett klein geschrieben und einzelne Wörter mit Unterstrichten getrennt (beispielsweise + bad_function_params.t). + + Unterverzeichnisse sollten grob nach dem Themenbereich benannt sind, mit dem sich die Scripte darin befassen + (beispielsweise background_jobs für Tests rund um Hintergrund-Jobs). + + Test-Scripte sollten einen überschaubaren Bereich von Funktionalität testen, der logisch zusammenhängend ist + (z.B. nur Tests für eine einzelne Funktion in einem Modul). Lieber mehrere Test-Scripte schreiben. + + + + + + Minimales Skelett für eigene Scripte + + + Der folgenden Programmcode enthält das kleinstmögliche Testscript und kann als Ausgangspunkt für eigene Tests verwendet werden: + + use Test::More tests => 0; + +use lib 't'; + +use Support::TestSetup; + +Support::TestSetup::login(); + + Wird eine vollständig initialisierte kivitendo-Umgebung benötigt (Stichwort: alle globalen Variablen wie + $::auth, $::form oder $::lxdebug), so muss in der Konfigurationsdatei + config/kivitendo.conf im Abschnitt testing.login ein gültiger Login-Name eingetragen + sein. Dieser wird für die Datenbankverbindung benötigt. + + Wir keine vollständig initialisierte Umgebung benötigt, so kann die letzte Zeile Support::TestSetup::login(); + weggelassen werden, was die Ausführungszeit des Scripts leicht verringert. + + + + Stil-Richtlinien diff --git a/doc/html/ch02.html b/doc/html/ch02.html index 95ad65e7b..28b4e2233 100644 --- a/doc/html/ch02.html +++ b/doc/html/ch02.html @@ -6,10 +6,55 @@ bei der Auswahl der Pakete aber darauf Rücksicht genommen, dass es ohne große Probleme auf den derzeit aktuellen verbreiteten Distributionen läuft.

Mitte 2012 sind das folgende Systeme, von denen bekannt ist, - dass kivitendo auf ihnen läuft:

  • Ubuntu 10.04 LTS Lucid Lynx bis 12.04 Precise Pangolin

  • Debian 5.0 Lenny und 6.0 Squeeze

  • openSUSE 11.2 und 11.3

  • SuSE Linux Enterprice Server 11

  • Fedora 13 bis 16

2.1.2. Pakete

Zum Betrieb von kivitendo werden zwingend ein Webserver (meist + dass kivitendo auf ihnen läuft:

  • Ubuntu 10.04 LTS Lucid Lynx bis 12.10 Oneiric Ocelot

  • Debian 5.0 Lenny und 6.0 Squeeze

  • openSUSE 11.2 und 11.3

  • SuSE Linux Enterprice Server 11

  • Fedora 13 bis 16

2.1.2. Pakete

Zum Betrieb von kivitendo werden zwingend ein Webserver (meist Apache) und ein Datenbankserver (PostgreSQL, mindestens v8.2) benötigt.

Zusätzlich benötigt kivitendo die folgenden Perl-Pakete, die - nicht Bestandteil einer Standard-Perl-Installation sind:

  • parent

  • Archive::Zip

  • Config::Std

  • DateTime

  • DBI

  • DBD::Pg

  • Email::Address

  • JSON

  • List::MoreUtils

  • Params::Validate

  • PDF::API2

  • Rose::Object

  • Rose::DB

  • Rose::DB::Object

  • Template

  • Text::CSV_XS

  • Text::Iconv

  • URI

  • XML::Writer

  • YAML

Gegenüber Version 2.6.0 sind zu dieser Liste 2 Pakete + nicht Bestandteil einer Standard-Perl-Installation sind:

  • + parent +

  • + Archive::Zip +

  • + Config::Std +

  • + DateTime +

  • + DBI +

  • + DBD::Pg +

  • + Email::Address +

  • + Email::MIME +

  • + JSON +

  • + List::MoreUtils +

  • + Net::SMTP::SSL (optional, bei E-Mail-Versand über SSL; siehe Abschnitt "E-Mail-Versand über einen SMTP-Server")

  • + Net::SSLGlue (optional, bei E-Mail-Versand über TLS; siehe Abschnitt "E-Mail-Versand über einen SMTP-Server")

  • + Params::Validate +

  • + PDF::API2 +

  • + Rose::Object +

  • + Rose::DB +

  • + Rose::DB::Object +

  • + Template +

  • + Text::CSV_XS +

  • + Text::Iconv +

  • + URI +

  • + XML::Writer +

  • + YAML +

Seit v2.7.0 sind die folgenden Pakete hinzugekommen: Email::MIME, Net::SMTP::SSL, + Net::SSLGlue.

Gegenüber Version 2.6.0 sind zu dieser Liste 2 Pakete hinzugekommen, URI und XML::Writer sind notwendig. Ohne startet kivitendo nicht.

Gegenüber Version 2.6.1 sind parent, @@ -26,20 +71,18 @@ installieren.

Die zu installierenden Pakete können in den verschiedenen Distributionen unterschiedlich heißen.

Für Debian oder Ubuntu benötigen Sie diese Pakete:

apt-get install apache2 postgresql libparent-perl libarchive-zip-perl \
   libdatetime-perl libdbi-perl libdbd-pg-perl libpg-perl \
-  libemail-address-perl liblist-moreutils-perl libpdf-api2-perl \
+  libemail-address-perl libemail-mime-perl liblist-moreutils-perl libpdf-api2-perl \
   librose-object-perl librose-db-perl librose-db-object-perl \
   libtemplate-perl libtext-csv-xs-perl libtext-iconv-perl liburi-perl \
   libxml-writer-perl libyaml-perl libconfig-std-perl \
-  libparams-validate-perl libjson-perl libclass-accessor-perl

Für Fedora Core benötigen Sie diese Pakete:

yum install httpd postgresql-server perl-parent perl-DateTime \
-  perl-DBI perl-DBD-Pg perl-Email-Address perl-List-MoreUtils \
+  libparams-validate-perl libjson-perl libclass-accessor-perl \
+  libnet-sslglue-perl libnet-smtp-ssl-perl

Für Fedora Core benötigen Sie diese Pakete:

yum install httpd postgresql-server perl-parent perl-DateTime \
+  perl-DBI perl-DBD-Pg perl-Email-Address perl-Email-MIME perl-List-MoreUtils \
   perl-PDF-API2 perl-Rose-Object perl-Rose-DB perl-Rose-DB-Object \
   perl-Template-Toolkit perl-Text-CSV_XS perl-Text-Iconv perl-URI \
-  perl-XML-Writer perl-YAML

Für OpenSuSE benötigen Sie diese Pakete:

zypper install apache2 postgresql-server perl-Archive-Zip \
-  perl-DateTime perl-DBI perl-DBD-Pg perl-MailTools perl-List-MoreUtils \
+  perl-XML-Writer perl-YAML perl-Net-SSLGlue perl-Net-SMTP-SSL

Für OpenSuSE benötigen Sie diese Pakete:

zypper install apache2 postgresql-server perl-Archive-Zip \
+  perl-DateTime perl-DBI perl-DBD-Pg perl-Email-MIME perl-MailTools perl-List-MoreUtils \
   perl-PDF-API2 perl-Template-Toolkit perl-Text-CSV_XS perl-Text-Iconv \
-  perl-URI perl-XML-Writer perl-YAML

Bei openSuSE 11 ist parent bereits enthalten, - und braucht nicht nachinstalliert werden. Die - Rose::* Pakete sind derzeit nicht für SuSE gepackt, - und müssen anderweitig nachinstalliert werden.

kivitendo enthält ein Script, mit dem überprüft werden kann, ob + perl-URI perl-XML-Writer perl-YAML perl-Net-SSLGlue perl-Net-SMTP-SSL

kivitendo enthält ein Script, mit dem überprüft werden kann, ob alle benötigten Perl-Module installiert sind. Der Aufruf lautet wie folgt:

./scripts/installation_check.pl
\ No newline at end of file diff --git a/doc/html/ch02s03.html b/doc/html/ch02s03.html index 07797b895..248e638cd 100644 --- a/doc/html/ch02s03.html +++ b/doc/html/ch02s03.html @@ -19,22 +19,21 @@ verwaltet.

Die Konfiguration ist ferner serverabhängig, d.h. für alle Mandaten, bzw. Datenbanken gleich.

2.3.2. Abschnitte und Parameter

Die Konfigurationsdatei besteht aus mehreren Teilen, die entsprechend kommentiert sind:

2.4.4. Datenbankbenutzer anlegen

Wenn Sie nicht den Datenbanksuperuser “postgres” zum Zugriff benutzen wollen, so sollten Sie bei PostgreSQL einen neuen Benutzer anlegen. Ein Beispiel, wie Sie einen neuen Benutzer anlegen - können:

- - Die Frage, ob der neue User Superuser sein soll, können Sie mit nein - beantworten, genauso ist die Berechtigung neue User (Roles) zu - generieren nicht nötig. -
su - postgres
+        können:

su - postgres
 createuser -d -P kivitendo
 exit

Wenn Sie später einen Datenbankzugriff konfigurieren, verändern Sie den evtl. voreingestellten Benutzer “postgres” auf “kivitendo” bzw. diff --git a/doc/html/ch02s05.html b/doc/html/ch02s05.html index 5fcbf8346..523411b3b 100644 --- a/doc/html/ch02s05.html +++ b/doc/html/ch02s05.html @@ -1,6 +1,6 @@ - 2.5. Webserver-Konfiguration

2.5. Webserver-Konfiguration

2.5.1. Grundkonfiguration mittels CGI

[Anmerkung]Anmerkung

Für einen deutlichen Performanceschub sorgt die Ausführung + 2.5. Webserver-Konfiguration

2.5. Webserver-Konfiguration

2.5.1. Grundkonfiguration mittels CGI

[Anmerkung]Anmerkung

Für einen deutlichen Performanceschub sorgt die Ausführung mittels FastCGI/FCGI. Die Einrichtung wird ausführlich im Abschnitt Konfiguration für FastCGI/FCGI beschrieben.

Der Zugriff auf das Programmverzeichnis muss in der Apache Webserverkonfigurationsdatei httpd.conf eingestellt @@ -42,10 +42,9 @@ Alias /kivitendo-erp/ /var/www/kiviteno-erp/ wird nur die eigentliche Programmlogik ausgeführt.

2.5.2.3. Getestete Kombinationen aus Webservern und Plugin

Folgende Kombinationen sind getestet:

  • Apache 2.2.11 (Ubuntu) und mod_fcgid.

  • Apache 2.2.11 (Ubuntu) und mod_fastcgi.

Dabei wird mod_fcgid empfohlen, weil mod_fastcgi seit geraumer Zeit nicht mehr weiter entwickelt wird. Im Folgenden wird auf mod_fastcgi nicht mehr explizit eingegangen.

Als Perl Backend wird das Modul FCGI.pm - verwendet.

[Warnung]Warnung

FCGI 0.69 und höher ist extrem strict in der Behandlung von - Unicode, und verweigert bestimmte Eingaben von kivitendo. Falls es - Probleme mit Umlauten in Ihrere Installation gibt, muss auf die - Vorgängerversion FCGI 0.68 ausgewichen werden.

Mit CPAN lässt sie sich die Vorgängerversion wie folgt + verwendet.

[Warnung]Warnung

FCGI-Versionen ab 0.69 und bis zu 0.71 inklusive sind extrem strict in der Behandlung von Unicode, und verweigern + bestimmte Eingaben von kivitendo. Falls es Probleme mit Umlauten in Ihrere Installation gibt, muss zwingend Version 0.68 oder + aber Version 0.72 und neuer eingesetzt werden.

Mit CPAN lässt sie sich die Vorgängerversion wie folgt installieren:

force install M/MS/MSTROUT/FCGI-0.68.tar.gz

2.5.2.4. Konfiguration des Webservers

Bevor Sie versuchen, eine kivitendo Installation unter FCGI laufen zu lassen, empfliehlt es sich die Installation ersteinmal unter CGI aufzusetzen. FCGI macht es nicht einfach Fehler zu diff --git a/doc/html/ch02s06.html b/doc/html/ch02s06.html index 579aee556..5adbf1a26 100644 --- a/doc/html/ch02s06.html +++ b/doc/html/ch02s06.html @@ -29,7 +29,7 @@ Links aus einem der Runlevel-Verzeichnisse heraus in den Boot-Prozess einzubinden. Da das bei neueren Linux-Distributionen aber nicht zwangsläufig funktioniert, werden auch Start-Scripte mitgeliefert, die - anstelle eines symbolischen Links verwendet werden können.

2.6.2.1. SystemV-basierende Systeme (z.B. Debian, OpenSuSE, Fedora + anstelle eines symbolischen Links verwendet werden können.

2.6.2.1. SystemV-basierende Systeme (z.B. Debian, OpenSuSE, Fedora Core)

Kopieren Sie die Datei scripts/boot/system-v/kivitendo-server nach /etc/init.d/kivitendo-server. Passen @@ -40,7 +40,7 @@ insserv kivitendo-task-server

  • OpenSuSE und Fedora Core:

    chkconfig --add kivitendo-task-server
  • Danach kann der Task-Server mit dem folgenden Befehl gestartet werden: /etc/init.d/kivitendo-task-server start -

    2.6.2.2. Upstart-basierende Systeme (z.B. Ubuntu)

    Kopieren Sie die Datei +

    2.6.2.2. Upstart-basierende Systeme (z.B. Ubuntu)

    Kopieren Sie die Datei scripts/boot/upstart/kivitendo-task-server.conf nach /etc/init/kivitendo-task-server.conf. Passen Sie in der kopierten Datei den Pfad zum Task-Server an (Zeile diff --git a/doc/html/ch02s08.html b/doc/html/ch02s08.html index fb0710b92..2810a6c0e 100644 --- a/doc/html/ch02s08.html +++ b/doc/html/ch02s08.html @@ -1,6 +1,6 @@ - 2.8. Benutzer- und Gruppenverwaltung

    2.8. Benutzer- und Gruppenverwaltung

    Nach der Installation müssen Benutzer, Gruppen und Datenbanken + 2.8. Benutzer- und Gruppenverwaltung

    2.8. Benutzer- und Gruppenverwaltung

    Nach der Installation müssen Benutzer, Gruppen und Datenbanken angelegt werden. Dieses geschieht im Administrationsmenü, das Sie unter folgender URL finden:

    http://localhost/kivitendo-erp/admin.pl @@ -70,4 +70,4 @@ Funktionen von kivitendo gewährt. Alle migrierten Benutzern werden Mitglied in dieser Gruppe. Damit wird das Verhalten von kivitendo bis Version 2.4.3 inklusive wiederhergestellt, und die Benutzer können - sich sofort wieder anmelden und mit dem System arbeiten.

    \ No newline at end of file + sich sofort wieder anmelden und mit dem System arbeiten.

    \ No newline at end of file diff --git a/doc/html/ch02s09.html b/doc/html/ch02s09.html index a34ebb3e6..acfb79539 100644 --- a/doc/html/ch02s09.html +++ b/doc/html/ch02s09.html @@ -1,27 +1,36 @@ - 2.9. Drucken mit kivitendo

    2.9. Drucken mit kivitendo

    Das Drucksystem von kivitendo benutzt von Haus aus LaTeX Vorlagen. - Um drucken zu können, braucht der Server ein geeignetes LaTeX System. Am - einfachsten ist dazu eine texlive Installation. Unter - Debianoiden Betriebssystemen sind das die Pakete:

    - texlive-latex-base texlive-latex-extra - texlive-fonts-recommended -

    Diese hinteren beiden enthalten Bibliotheken und Schriftarten die - von den Standardvorlagen verwendet werden.

    TODO: rpm Pakete.

    In den allermeisten Installationen sollte drucken jetzt schon - funktionieren. Sollte ein Fehler auftreten wirft TeX sehr lange - Fehlerbeschreibungen, der eigentliche Fehler ist immer die erste Zeite - die mit einem Ausrufezeichen anfängt. Häufig auftretende Fehler sind zum - Beispiel:

    • ! LaTeX Error: File `eurosym.sty' not found. Die entsprechende - LaTeX-Bibliothek wurde nicht gefunden. Das tritt vor allem bei - Vorlagen aus der Community auf. Installieren Sie die entsprechenden - Pakete.

    • ! Package inputenc Error: Unicode char \u8:桜 not set up for - use with LaTeX. Dieser Fehler tritt auf, wenn sie versuchen mit - einer Standardinstallation exotische utf8 Zeichen zu drucken. - TeXLive unterstützt von Haus nur romanische Schriften und muss mit - diversen Tricks dazu gebracht werden andere Zeichen zu akzeptieren. - Adere TeX Systeme wie XeTeX schaffen hier Abhilfe.

    Wird garkein Fehler angezeigt sondern nur der Name des Templates, - heißt das normalerweise, dass das LaTeX Binary nicht gefunden wurde. - Prüfen Sie den Namen in der Konfiguration (Standard: - pdflatex), und stellen Sie sicher, dass pdflatex - (oder das von Ihnen verwendete System) vom Webserver ausgeführt werden - darf.

    \ No newline at end of file + 2.9. E-Mail-Versand aus kivitendo heraus

    2.9. E-Mail-Versand aus kivitendo heraus

    kivitendo kann direkt aus dem Programm heraus E-Mails versenden, z.B. um ein Angebot direkt an einen Kunden zu + verschicken. Damit dies funktioniert, muss eingestellt werden, über welchen Server die E-Mails verschickt werden sollen. kivitendo + unterstützt dabei zwei Mechanismen: Versand über einen lokalen E-Mail-Server (z.B. mit Postfix™ oder + Exim™, was auch die standardmäßig aktive Methode ist) sowie Versand über einen SMTP-Server (z.B. der des + eigenen Internet-Providers).

    Welche Methode und welcher Server verwendet werden, wird über die Konfigurationsdatei config/kivitendo.conf + festgelegt. Dort befinden sich alle Einstellungen zu diesem Thema im Abschnitt '[mail_delivery]'.

    2.9.1. Versand über lokalen E-Mail-Server

    Diese Methode bietet sich an, wenn auf dem Server, auf dem kivitendo läuft, bereits ein funktionsfähiger E-Mail-Server wie + z.B. Postfix™, Exim™ oder Sendmail™ läuft.

    Um diese Methode auszuwählen, muss der Konfigurationsparameter 'method = sendmail' gesetzt sein. Dies ist + gleichzeitig der Standardwert, falls er nicht verändert wird.

    Um zu kontrollieren, wie das Programm zum Einliefern gestartet wird, dient der Parameter 'sendmail = + ...'. Der Standardwert verweist auf das Programm /usr/bin/sendmail, das bei allen oben genannten + E-Mail-Serverprodukten für diesen Zweck funktionieren sollte.

    Die Konfiguration des E-Mail-Servers selber würde den Rahmen dieses sprengen. Hierfür sei auf die Dokumentation des + E-Mail-Servers verwiesen.

    2.9.2. Versand über einen SMTP-Server

    Diese Methode bietet sich an, wenn kein lokaler E-Mail-Server vorhanden oder zwar einer vorhanden, dieser aber nicht + konfiguriert ist.

    Um diese Methode auszuwählen, muss der Konfigurationsparameter 'method = smtp' gesetzt sein. Die folgenden + Parameter dienen dabei der weiteren Konfiguration:

    + hostname +

    Name oder IP-Adresse des SMTP-Servers. Standardwert: 'localhost'

    + port +

    Portnummer. Der Standardwert hängt von der verwendeten Verschlüsselungsmethode ab. Gilt 'security = + none' oder 'security = tls', so ist 25 die Standardportnummer. Für 'security = + ssl' ist 465 die Portnummer. Muss normalerweise nicht geändert werden.

    + security +

    Wahl der zu verwendenden Verschlüsselung der Verbindung mit dem Server. Standardwert ist + 'none', wodurch keine Verschlüsselung verwendet wird. Mit 'tls' wird TLS-Verschlüsselung + eingeschaltet, und mit 'ssl' wird Verschlüsselung via SSL eingeschaltet. Achtung: Für + 'tls' und 'ssl' werden zusätzliche Perl-Module benötigt (siehe unten).

    + login und password +

    Falls der E-Mail-Server eine Authentifizierung verlangt, so können mit diesen zwei Parametern der Benutzername + und das Passwort angegeben werden. Wird Authentifizierung verwendet, so sollte aus Sicherheitsgründen auch eine Form von + Verschlüsselung aktiviert werden.

    Wird Verschlüsselung über TLS oder SSL aktiviert, so werden zusätzliche Perl-Module benötigt. Diese sind:

    • TLS-Verschlüsselung: Modul Net::SSLGlue (Debian-Paketname + libnet-sslglue-perl, Fedora Core: perl-Net-SSLGlue, openSuSE: + perl-Net-SSLGlue +

    • SSL-Verschlüsselung: Modul Net::SMTP::SSL (Debian-Paketname + libnet-smtp-ssl-perl, Fedora Core: perl-Net-SMTP-SSL, openSuSE: + perl-Net-SMTP-SSL +

    \ No newline at end of file diff --git a/doc/html/ch02s10.html b/doc/html/ch02s10.html index 72b49b1be..d9bbfec8d 100644 --- a/doc/html/ch02s10.html +++ b/doc/html/ch02s10.html @@ -1,58 +1,27 @@ - 2.10. OpenDocument-Vorlagen

    2.10. OpenDocument-Vorlagen

    kivitendo unterstützt die Verwendung von Vorlagen im - OpenDocument-Format, wie es OpenOffice.org ab Version 2 erzeugt. - kivitendo kann dabei sowohl neue OpenDocument-Dokumente als auch aus - diesen direkt PDF-Dateien erzeugen. Um die Unterstützung von - OpenDocument-Vorlagen zu aktivieren muss in der Datei - config/kivitendo.conf die Variable - opendocument im Abschnitt - print_templates auf ‘1’ stehen. - Dieses ist die Standardeinstellung.

    Weiterhin muss in der Datei - config/kivitendo.conf die Variable - dbcharset im Abschnitt system auf - die Zeichenkodierung gesetzt werden, die auch bei der Speicherung der - Daten in der Datenbank verwendet wird. Diese ist in den meisten Fällen - "UTF-8".

    Während die Erzeugung von reinen OpenDocument-Dateien keinerlei - weitere Software benötigt, wird zur Umwandlung dieser Dateien in PDF - OpenOffice.org benötigt. Soll dieses Feature genutzt werden, so muss - neben OpenOffice.org ab Version 2 auch der “X virtual frame buffer” - (xvfb) installiert werden. Bei Debian ist er im Paket “xvfb” enthalten. - Andere Distributionen enthalten ihn in anderen Paketen.

    Nach der Installation müssen in der Datei - config/kivitendo.conf zwei weitere Variablen - angepasst werden: openofficeorg_writer muss den - vollständigen Pfad zur OpenOffice.org Writer-Anwendung enthalten. - xvfb muss den Pfad zum “X virtual frame buffer” - enthalten. Beide stehen im Abschnitt - applications.

    Zusätzlich gibt es zwei verschiedene Arten, wie kivitendo mit - OpenOffice kommuniziert. Die erste Variante, die benutzt wird, wenn die - Variable $openofficeorg_daemon gesetzt ist, startet - ein OpenOffice, das auch nach der Umwandlung des Dokumentes gestartet - bleibt. Bei weiteren Umwandlungen wird dann diese laufende Instanz - benutzt. Der Vorteil ist, dass die Zeit zur Umwandlung deutlich - reduziert wird, weil nicht für jedes Dokument ein OpenOffice gestartet - werden muss. Der Nachteil ist, dass diese Methode Python und die - Python-UNO-Bindings benötigt, die Bestandteil von OpenOffice 2 - sind.

    Ist $openofficeorg_daemon nicht gesetzt, so - wird für jedes Dokument OpenOffice neu gestartet und die Konvertierung - mit Hilfe eines Makros durchgeführt. Dieses Makro muss in der - Dokumentenvorlage enthalten sein und - “Standard.Conversion.ConvertSelfToPDF()” heißen. Die Beispielvorlage - ‘templates/mastertemplates/German/invoice.odt’ - enthält ein solches Makro, das in jeder anderen Dokumentenvorlage - ebenfalls enthalten sein muss.

    Als letztes muss herausgefunden werden, welchen Namen - OpenOffice.org Writer dem Verzeichnis mit den Benutzereinstellungen - gibt. Unter Debian ist dies momentan - ~/.openoffice.org2. Sollte der Name bei Ihrer - OpenOffice.org-Installation anders sein, so muss das Verzeichnis - users/.openoffice.org2 entsprechend umbenannt werden. - Ist der Name z.B. einfach nur .openoffice, so wäre - folgender Befehl auszuführen:

    - mv users/.openoffice.org2 - users/.openoffice -

    Dieses Verzeichnis, wie auch das komplette - users-Verzeichnis, muss vom Webserver beschreibbar - sein. Dieses wurde bereits erledigt (siehe Manuelle Installation des Programmpaketes), kann aber - erneut überprüft werden, wenn die Konvertierung nach PDF - fehlschlägt.

    \ No newline at end of file + 2.10. Drucken mit kivitendo

    2.10. Drucken mit kivitendo

    Das Drucksystem von kivitendo benutzt von Haus aus LaTeX Vorlagen. + Um drucken zu können, braucht der Server ein geeignetes LaTeX System. Am + einfachsten ist dazu eine texlive Installation. Unter + Debianoiden Betriebssystemen sind das die Pakete:

    + texlive-latex-base texlive-latex-extra + texlive-fonts-recommended +

    Diese hinteren beiden enthalten Bibliotheken und Schriftarten die + von den Standardvorlagen verwendet werden.

    TODO: rpm Pakete.

    In den allermeisten Installationen sollte drucken jetzt schon + funktionieren. Sollte ein Fehler auftreten wirft TeX sehr lange + Fehlerbeschreibungen, der eigentliche Fehler ist immer die erste Zeite + die mit einem Ausrufezeichen anfängt. Häufig auftretende Fehler sind zum + Beispiel:

    • ! LaTeX Error: File `eurosym.sty' not found. Die entsprechende + LaTeX-Bibliothek wurde nicht gefunden. Das tritt vor allem bei + Vorlagen aus der Community auf. Installieren Sie die entsprechenden + Pakete.

    • ! Package inputenc Error: Unicode char \u8:桜 not set up for + use with LaTeX. Dieser Fehler tritt auf, wenn sie versuchen mit + einer Standardinstallation exotische utf8 Zeichen zu drucken. + TeXLive unterstützt von Haus nur romanische Schriften und muss mit + diversen Tricks dazu gebracht werden andere Zeichen zu akzeptieren. + Adere TeX Systeme wie XeTeX schaffen hier Abhilfe.

    Wird garkein Fehler angezeigt sondern nur der Name des Templates, + heißt das normalerweise, dass das LaTeX Binary nicht gefunden wurde. + Prüfen Sie den Namen in der Konfiguration (Standard: + pdflatex), und stellen Sie sicher, dass pdflatex + (oder das von Ihnen verwendete System) vom Webserver ausgeführt werden + darf.

    \ No newline at end of file diff --git a/doc/html/ch02s11.html b/doc/html/ch02s11.html index dcb4c7eec..94228a0f8 100644 --- a/doc/html/ch02s11.html +++ b/doc/html/ch02s11.html @@ -1,63 +1,58 @@ - 2.11. Konfiguration zur Einnahmenüberschussrechnung/Bilanzierung: EUR

    2.11. Konfiguration zur Einnahmenüberschussrechnung/Bilanzierung: - EUR

    2.11.1. Einführung

    kivitendo besaß bis inklusive Version 2.6.3 einen - Konfigurationsparameter namens eur, der sich in der - Konfigurationsdatei config/lx_office.conf - befand. Somit galt er für alle Mandanten, die in dieser Installation - benutzt wurden.

    Mit der nachfolgenden Version wurde der Parameter zum Einen in - die Mandantendatenbank verschoben und dabei auch gleich in drei - Einzelparameter aufgeteilt, mit denen sich das Verhalten genauer - steuern lässt.

    2.11.2. Konfigurationsparameter

    Es gibt drei Parameter, die die Gewinnermittlungsart, - Versteuerungsart und die Warenbuchungsmethode regeln:

    - profit_determination -

    Dieser Parameter legt die Berechnungsmethode für die - Gewinnermittlung fest. Er enthält entweder - balance für - Betriebsvermögensvergleich/Bilanzierung oder - income für die - Einnahmen-Überschuss-Rechnung.

    - accounting_method -

    Dieser Parameter steuert die Buchungs- und - Berechnungsmethoden für die Versteuerungsart. Er enthält - entweder accrual für die Soll-Versteuerung - oder cash für die Ist-Versteuerung.

    - inventory_system -

    Dieser Parameter legt die Warenbuchungsmethode fest. Er - enthält entweder perpetual für die - Bestandsmethode oder periodic für die - Aufwandsmethode.

    Zum Vergleich der Funktionalität bis und nach 2.6.3: - eur = 1 bedeutete Einnahmen-Überschuss-Rechnung, - Ist-Versteuerung und Aufwandsmethode. eur = 0 - bedeutete hingegen Bilanzierung, Soll-Versteuerung und - Bestandsmethode.

    Die Konfiguration "eur" unter - [system] in der Konfigurationsdatei - - config/kivitendo.conf wird nun nicht mehr - benötigt und kann entfernt werden. Dies muss manuell geschehen.

    2.11.3. Festlegen der Parameter

    Beim Anlegen eines neuen Mandanten bzw. einer neuen Datenbank in - der Admininstration können diese Optionen nun unabhängig voneinander - eingestellt werden.

    Beim Upgrade bestehender Mandanten wird eur ausgelesen und die - Variablen werden so gesetzt, daß sich an der Funktionalität nichts - ändert.

    Die aktuelle Konfiguration wird unter Nummernkreise und - Standardkonten unter dem neuen Punkt "Einstellungen" angezeigt - (read-only). Eine spätere Änderung ist für einen bestehenden Mandanten - nicht mehr möglich. Dies war auch vorher nicht möglich, bzw. - vorhandene Daten wurden so belassen und haben damit die Ergebnisse - verfälscht.

    2.11.4. Bemerkungen zu Bestandsmethode

    Die Bestandsmethode ist eigentlich eine sehr elegante Methode, - funktioniert in kivitendo aber nur unter bestimmten Bedingungen: - Voraussetzung ist, daß auch immer alle Einkaufsrechnungen gepflegt - werden, und man beim Jahreswechsel nicht mit einer leeren Datenbank - anfängt, da bei jedem Verkauf anhand der gesamten Rechnungshistorie - der Einkaufswert der Ware nach dem FIFO-Prinzip aus den - Einkaufsrechnungen berechnet wird.

    Die Bestandsmethode kann vom Prinzip her also nur funktioneren, - wenn man mit den Buchungen bei Null anfängt, und man kann auch nicht - im laufenden Betrieb von der Aufwandsmethode zur Bestandsmethode - wechseln.

    2.11.5. Bekannte Probleme

    Bei bestimmten Berichten kann man derzeit noch inviduell - einstellen, ob man nach Ist- oder Sollversteuerung auswertet, und es - werden im Code Variablen wie $accrual oder $cash gesetzt. Diese - Codestellen wurden noch nicht angepasst, sondern nur die, wo bisher - die Konfigurationsvariable - $::lx_office_conf{system}->{eur} ausgewertet - wurde.

    Es fehlen Hilfetext beim Neuanlegen eines Mandanten, was die - Optionen bewirken, z.B. mit zwei Standardfällen.

    \ No newline at end of file + 2.11. OpenDocument-Vorlagen

    2.11. OpenDocument-Vorlagen

    kivitendo unterstützt die Verwendung von Vorlagen im + OpenDocument-Format, wie es OpenOffice.org ab Version 2 erzeugt. + kivitendo kann dabei sowohl neue OpenDocument-Dokumente als auch aus + diesen direkt PDF-Dateien erzeugen. Um die Unterstützung von + OpenDocument-Vorlagen zu aktivieren muss in der Datei + config/kivitendo.conf die Variable + opendocument im Abschnitt + print_templates auf ‘1’ stehen. + Dieses ist die Standardeinstellung.

    Weiterhin muss in der Datei + config/kivitendo.conf die Variable + dbcharset im Abschnitt system auf + die Zeichenkodierung gesetzt werden, die auch bei der Speicherung der + Daten in der Datenbank verwendet wird. Diese ist in den meisten Fällen + "UTF-8".

    Während die Erzeugung von reinen OpenDocument-Dateien keinerlei + weitere Software benötigt, wird zur Umwandlung dieser Dateien in PDF + OpenOffice.org benötigt. Soll dieses Feature genutzt werden, so muss + neben OpenOffice.org ab Version 2 auch der “X virtual frame buffer” + (xvfb) installiert werden. Bei Debian ist er im Paket “xvfb” enthalten. + Andere Distributionen enthalten ihn in anderen Paketen.

    Nach der Installation müssen in der Datei + config/kivitendo.conf zwei weitere Variablen + angepasst werden: openofficeorg_writer muss den + vollständigen Pfad zur OpenOffice.org Writer-Anwendung enthalten. + xvfb muss den Pfad zum “X virtual frame buffer” + enthalten. Beide stehen im Abschnitt + applications.

    Zusätzlich gibt es zwei verschiedene Arten, wie kivitendo mit + OpenOffice kommuniziert. Die erste Variante, die benutzt wird, wenn die + Variable $openofficeorg_daemon gesetzt ist, startet + ein OpenOffice, das auch nach der Umwandlung des Dokumentes gestartet + bleibt. Bei weiteren Umwandlungen wird dann diese laufende Instanz + benutzt. Der Vorteil ist, dass die Zeit zur Umwandlung deutlich + reduziert wird, weil nicht für jedes Dokument ein OpenOffice gestartet + werden muss. Der Nachteil ist, dass diese Methode Python und die + Python-UNO-Bindings benötigt, die Bestandteil von OpenOffice 2 + sind.

    Ist $openofficeorg_daemon nicht gesetzt, so + wird für jedes Dokument OpenOffice neu gestartet und die Konvertierung + mit Hilfe eines Makros durchgeführt. Dieses Makro muss in der + Dokumentenvorlage enthalten sein und + “Standard.Conversion.ConvertSelfToPDF()” heißen. Die Beispielvorlage + ‘templates/mastertemplates/German/invoice.odt’ + enthält ein solches Makro, das in jeder anderen Dokumentenvorlage + ebenfalls enthalten sein muss.

    Als letztes muss herausgefunden werden, welchen Namen + OpenOffice.org Writer dem Verzeichnis mit den Benutzereinstellungen + gibt. Unter Debian ist dies momentan + ~/.openoffice.org2. Sollte der Name bei Ihrer + OpenOffice.org-Installation anders sein, so muss das Verzeichnis + users/.openoffice.org2 entsprechend umbenannt werden. + Ist der Name z.B. einfach nur .openoffice, so wäre + folgender Befehl auszuführen:

    + mv users/.openoffice.org2 + users/.openoffice +

    Dieses Verzeichnis, wie auch das komplette + users-Verzeichnis, muss vom Webserver beschreibbar + sein. Dieses wurde bereits erledigt (siehe Manuelle Installation des Programmpaketes), kann aber + erneut überprüft werden, wenn die Konvertierung nach PDF + fehlschlägt.

    \ No newline at end of file diff --git a/doc/html/ch02s12.html b/doc/html/ch02s12.html index 4836d3a60..e7575f997 100644 --- a/doc/html/ch02s12.html +++ b/doc/html/ch02s12.html @@ -1,36 +1,63 @@ - 2.12. SKR04 19% Umstellung für innergemeinschaftlichen Erwerb

    2.12. SKR04 19% Umstellung für innergemeinschaftlichen Erwerb

    2.12.1. Einführung

    Die Umsatzsteuerumstellung auf 19% für SKR04 für die - Steuerschlüssel "EU ohne USt-ID Nummer" ist erst 2010 erfolgt. - kivitendo beinhaltet ein Upgradeskript, das das Konto 3804 automatisch - erstellt und die Steuereinstellungen korrekt einstellt. Hat der - Benutzer aber schon selber das Konto 3804 angelegt, oder gab es schon - Buchungen im Zeitraum nach dem 01.01.2007 auf das Konto 3803, wird das - Upgradeskript vorsichtshalber nicht ausgeführt, da der Benutzer sich - vielleicht schon selbst geholfen hat und mit seinen Änderungen - zufrieden ist. Die korrekten Einstellungen kann man aber auch per Hand - ausführen. Nachfolgend werden die entsprechenden Schritte anhand von - Screenshots dargestellt.

    Für den Fall, daß Buchungen mit der Steuerschlüssel "EU ohne - USt.-IdNr." nach dem 01.01.2007 erfolgt sind, ist davon auszugehen, - dass diese mit dem alten Umsatzsteuersatz von 16% gebucht worden sind, - und diese Buchungen sollten entsprechend kontrolliert werden.

    2.12.2. Konto 3804 manuell anlegen

    Die folgenden Schritte sind notwendig, um das Konto manuell - anzulegen und zu konfigurieren. Zuerst wird in - System -> - Kontenübersicht -> Konto - erfassen das Konto angelegt.

    - Als Zweites muss Steuergruppe 13 für Konto 3803 angepasst werden. Dazu unter System -> - Steuern -> Bearbeiten den Eintrag mit Steuerschlüssel 13 auswählen und ihn - wie im folgenden Screenshot angezeigt anpassen. -

    - Als Drittes wird ein neuer Eintrag mit Steuerschlüssel 13 für Konto 3804 (19%) angelegt. Dazu unter System -> - Steuern -> Erfassen auswählen und die Werte aus dem Screenshot übernehmen. -

    - Als Nächstes sind alle Konten anzupassen, die als Steuerautomatikkonto die 3803 haben, sodass sie ab dem 1.1.2007 auch - Steuerautomatik auf 3804 bekommen. Dies betrifft in der Standardkonfiguration die Konten 4315 und 4726. Als Beispiel für 4315 - müssen Sie dazu unter System -> Kontenübersicht -> Konten - anzeigen das Konto 4315 anklicken und die Einstellungen wie im Screenshot gezeigt vornehmen. -

    - Als Letztes sollte die Steuerliste unter System -> Steuern -> - Bearbeiten kontrolliert werden. Zum Vergleich der Screenshot. -

    \ No newline at end of file + 2.12. Konfiguration zur Einnahmenüberschussrechnung/Bilanzierung: EUR

    2.12. Konfiguration zur Einnahmenüberschussrechnung/Bilanzierung: + EUR

    2.12.1. Einführung

    kivitendo besaß bis inklusive Version 2.6.3 einen + Konfigurationsparameter namens eur, der sich in der + Konfigurationsdatei config/lx_office.conf + befand. Somit galt er für alle Mandanten, die in dieser Installation + benutzt wurden.

    Mit der nachfolgenden Version wurde der Parameter zum Einen in + die Mandantendatenbank verschoben und dabei auch gleich in drei + Einzelparameter aufgeteilt, mit denen sich das Verhalten genauer + steuern lässt.

    2.12.2. Konfigurationsparameter

    Es gibt drei Parameter, die die Gewinnermittlungsart, + Versteuerungsart und die Warenbuchungsmethode regeln:

    + profit_determination +

    Dieser Parameter legt die Berechnungsmethode für die + Gewinnermittlung fest. Er enthält entweder + balance für + Betriebsvermögensvergleich/Bilanzierung oder + income für die + Einnahmen-Überschuss-Rechnung.

    + accounting_method +

    Dieser Parameter steuert die Buchungs- und + Berechnungsmethoden für die Versteuerungsart. Er enthält + entweder accrual für die Soll-Versteuerung + oder cash für die Ist-Versteuerung.

    + inventory_system +

    Dieser Parameter legt die Warenbuchungsmethode fest. Er + enthält entweder perpetual für die + Bestandsmethode oder periodic für die + Aufwandsmethode.

    Zum Vergleich der Funktionalität bis und nach 2.6.3: + eur = 1 bedeutete Einnahmen-Überschuss-Rechnung, + Ist-Versteuerung und Aufwandsmethode. eur = 0 + bedeutete hingegen Bilanzierung, Soll-Versteuerung und + Bestandsmethode.

    Die Konfiguration "eur" unter + [system] in der Konfigurationsdatei + + config/kivitendo.conf wird nun nicht mehr + benötigt und kann entfernt werden. Dies muss manuell geschehen.

    2.12.3. Festlegen der Parameter

    Beim Anlegen eines neuen Mandanten bzw. einer neuen Datenbank in + der Admininstration können diese Optionen nun unabhängig voneinander + eingestellt werden.

    Beim Upgrade bestehender Mandanten wird eur ausgelesen und die + Variablen werden so gesetzt, daß sich an der Funktionalität nichts + ändert.

    Die aktuelle Konfiguration wird unter Nummernkreise und + Standardkonten unter dem neuen Punkt "Einstellungen" angezeigt + (read-only). Eine spätere Änderung ist für einen bestehenden Mandanten + nicht mehr möglich. Dies war auch vorher nicht möglich, bzw. + vorhandene Daten wurden so belassen und haben damit die Ergebnisse + verfälscht.

    2.12.4. Bemerkungen zu Bestandsmethode

    Die Bestandsmethode ist eigentlich eine sehr elegante Methode, + funktioniert in kivitendo aber nur unter bestimmten Bedingungen: + Voraussetzung ist, daß auch immer alle Einkaufsrechnungen gepflegt + werden, und man beim Jahreswechsel nicht mit einer leeren Datenbank + anfängt, da bei jedem Verkauf anhand der gesamten Rechnungshistorie + der Einkaufswert der Ware nach dem FIFO-Prinzip aus den + Einkaufsrechnungen berechnet wird.

    Die Bestandsmethode kann vom Prinzip her also nur funktioneren, + wenn man mit den Buchungen bei Null anfängt, und man kann auch nicht + im laufenden Betrieb von der Aufwandsmethode zur Bestandsmethode + wechseln.

    2.12.5. Bekannte Probleme

    Bei bestimmten Berichten kann man derzeit noch inviduell + einstellen, ob man nach Ist- oder Sollversteuerung auswertet, und es + werden im Code Variablen wie $accrual oder $cash gesetzt. Diese + Codestellen wurden noch nicht angepasst, sondern nur die, wo bisher + die Konfigurationsvariable + $::lx_office_conf{system}->{eur} ausgewertet + wurde.

    Es fehlen Hilfetext beim Neuanlegen eines Mandanten, was die + Optionen bewirken, z.B. mit zwei Standardfällen.

    \ No newline at end of file diff --git a/doc/html/ch02s13.html b/doc/html/ch02s13.html index 3b0f2ec0a..0b1381460 100644 --- a/doc/html/ch02s13.html +++ b/doc/html/ch02s13.html @@ -1,8 +1,36 @@ - 2.13. kivitendo ERP verwenden

    2.13. kivitendo ERP verwenden

    Nach erfolgreicher Installation ist der Loginbildschirm unter - folgender URL erreichbar:

    - http://localhost/kivitendo-erp/login.pl -

    Die Administrationsseite erreichen Sie unter:

    - http://localhost/kivitendo-erp/admin.pl -

    \ No newline at end of file + 2.13. SKR04 19% Umstellung für innergemeinschaftlichen Erwerb

    2.13. SKR04 19% Umstellung für innergemeinschaftlichen Erwerb

    2.13.1. Einführung

    Die Umsatzsteuerumstellung auf 19% für SKR04 für die + Steuerschlüssel "EU ohne USt-ID Nummer" ist erst 2010 erfolgt. + kivitendo beinhaltet ein Upgradeskript, das das Konto 3804 automatisch + erstellt und die Steuereinstellungen korrekt einstellt. Hat der + Benutzer aber schon selber das Konto 3804 angelegt, oder gab es schon + Buchungen im Zeitraum nach dem 01.01.2007 auf das Konto 3803, wird das + Upgradeskript vorsichtshalber nicht ausgeführt, da der Benutzer sich + vielleicht schon selbst geholfen hat und mit seinen Änderungen + zufrieden ist. Die korrekten Einstellungen kann man aber auch per Hand + ausführen. Nachfolgend werden die entsprechenden Schritte anhand von + Screenshots dargestellt.

    Für den Fall, daß Buchungen mit der Steuerschlüssel "EU ohne + USt.-IdNr." nach dem 01.01.2007 erfolgt sind, ist davon auszugehen, + dass diese mit dem alten Umsatzsteuersatz von 16% gebucht worden sind, + und diese Buchungen sollten entsprechend kontrolliert werden.

    2.13.2. Konto 3804 manuell anlegen

    Die folgenden Schritte sind notwendig, um das Konto manuell + anzulegen und zu konfigurieren. Zuerst wird in + System -> + Kontenübersicht -> Konto + erfassen das Konto angelegt.

    + Als Zweites muss Steuergruppe 13 für Konto 3803 angepasst werden. Dazu unter System -> + Steuern -> Bearbeiten den Eintrag mit Steuerschlüssel 13 auswählen und ihn + wie im folgenden Screenshot angezeigt anpassen. +

    + Als Drittes wird ein neuer Eintrag mit Steuerschlüssel 13 für Konto 3804 (19%) angelegt. Dazu unter System -> + Steuern -> Erfassen auswählen und die Werte aus dem Screenshot übernehmen. +

    + Als Nächstes sind alle Konten anzupassen, die als Steuerautomatikkonto die 3803 haben, sodass sie ab dem 1.1.2007 auch + Steuerautomatik auf 3804 bekommen. Dies betrifft in der Standardkonfiguration die Konten 4315 und 4726. Als Beispiel für 4315 + müssen Sie dazu unter System -> Kontenübersicht -> Konten + anzeigen das Konto 4315 anklicken und die Einstellungen wie im Screenshot gezeigt vornehmen. +

    + Als Letztes sollte die Steuerliste unter System -> Steuern -> + Bearbeiten kontrolliert werden. Zum Vergleich der Screenshot. +

    \ No newline at end of file diff --git a/doc/html/ch02s14.html b/doc/html/ch02s14.html new file mode 100644 index 000000000..9edfe595f --- /dev/null +++ b/doc/html/ch02s14.html @@ -0,0 +1,8 @@ + + + 2.14. kivitendo ERP verwenden

    2.14. kivitendo ERP verwenden

    Nach erfolgreicher Installation ist der Loginbildschirm unter + folgender URL erreichbar:

    + http://localhost/kivitendo-erp/login.pl +

    Die Administrationsseite erreichen Sie unter:

    + http://localhost/kivitendo-erp/admin.pl +

    \ No newline at end of file diff --git a/doc/html/ch03.html b/doc/html/ch03.html index 40ac50f65..036d39184 100644 --- a/doc/html/ch03.html +++ b/doc/html/ch03.html @@ -1,6 +1,6 @@ - Kapitel 3. Features und Funktionen

    Kapitel 3. Features und Funktionen

    3.1. Wiederkehrende Rechnungen

    3.1.1. Einführung

    Wiederkehrende Rechnungen werden als normale Aufträge definiert + Kapitel 3. Features und Funktionen

    Kapitel 3. Features und Funktionen

    3.1. Wiederkehrende Rechnungen

    3.1.1. Einführung

    Wiederkehrende Rechnungen werden als normale Aufträge definiert und konfiguriert, mit allen dazugehörigen Kunden- und Artikelangaben. Die konfigurierten Aufträge werden später automatisch in Rechnungen umgewandelt, so als ob man den Workflow benutzen würde, und auch die @@ -51,4 +51,4 @@ den neu konfigurieren Auftrag erkennt und daraus eine Rechnung generiert hat. Alternativ setzt man das Startdatum auf den Monatsersten des Folgemonats und erstellt die erste Rechnung direkt - manuell über den Workflow.

    \ No newline at end of file + manuell über den Workflow.

    \ No newline at end of file diff --git a/doc/html/ch03s02.html b/doc/html/ch03s02.html index e92ccc446..d6d1af492 100644 --- a/doc/html/ch03s02.html +++ b/doc/html/ch03s02.html @@ -556,7 +556,7 @@ invdate

    Rechnungsdatum

    invnumber -

    Rechnungsnummer

    3.2.10. Variablen in anderen Vorlagen

    3.2.10.1. Einführung

    Die Variablen in anderen Vorlagen sind ähnlich wie in der +

    Rechnungsnummer

    3.2.10. Variablen in anderen Vorlagen

    3.2.10.1. Einführung

    Die Variablen in anderen Vorlagen sind ähnlich wie in der Rechnung. Allerdings heißen die Variablen, die mit inv beginnen, jetzt anders. Bei den Angeboten fangen sie mit quo für "quotation" an: diff --git a/doc/html/ch04.html b/doc/html/ch04.html index 83fbf2890..722ed3a24 100644 --- a/doc/html/ch04.html +++ b/doc/html/ch04.html @@ -1,6 +1,6 @@ - Kapitel 4. Entwicklerdokumentation

    Kapitel 4. Entwicklerdokumentation

    4.1. Globale Variablen

    4.1.1. Wie sehen globale Variablen in Perl aus?

    Globale Variablen liegen in einem speziellen namespace namens + Kapitel 4. Entwicklerdokumentation

    Kapitel 4. Entwicklerdokumentation

    4.1. Globale Variablen

    4.1.1. Wie sehen globale Variablen in Perl aus?

    Globale Variablen liegen in einem speziellen namespace namens "main", der von überall erreichbar ist. Darüber hinaus sind bareword globs global und die meisten speziellen Variablen sind... speziell.

    Daraus ergeben sich folgende Formen:

    @@ -25,7 +25,7 @@ $PACKAGE::form.

    local $form

    Alle Änderungen an $form werden am Ende - des scopes zurückgesetzt

    4.1.2. Warum sind globale Variablen ein Problem?

    Das erste Problem ist FCGI™.

    + des scopes zurückgesetzt

    4.1.2. Warum sind globale Variablen ein Problem?

    Das erste Problem ist FCGI™.

    SQL-Ledger™ hat fast alles im globalen namespace abgelegt, und erwartet, dass es da auch wiederzufinden ist. Unter FCGI™ müssen diese Sachen aber wieder @@ -39,7 +39,7 @@ dies hat, seit der Einführung, u.a. schon so manche langwierige Bug-Suche verkürzt. Da globale Variablen aber implizit mit Package angegeben werden, werden die nicht geprüft, und somit kann sich - schnell ein Tippfehler einschleichen.

    4.1.3. Kanonische globale Variablen

    Um dieses Problem im Griff zu halten gibt es einige wenige + schnell ein Tippfehler einschleichen.

    4.1.3. Kanonische globale Variablen

    Um dieses Problem im Griff zu halten gibt es einige wenige globale Variablen, die kanonisch sind, d.h. sie haben bestimmte vorgegebenen Eigenschaften, und alles andere sollte anderweitig umhergereicht werden.

    Diese Variablen sind im Moment die folgenden neun:

    • @@ -62,7 +62,7 @@ $::request

    Damit diese nicht erneut als Müllhalde missbraucht werden, im Folgenden eine kurze Erläuterung der bestimmten vorgegebenen - Eigenschaften (Konventionen):

    4.1.3.1. $::form

    • Ist ein Objekt der Klasse + Eigenschaften (Konventionen):

      4.1.3.1. $::form

      • Ist ein Objekt der Klasse "Form"

      • Wird nach jedem Request gelöscht

      • Muss auch in Tests und Konsolenscripts vorhanden sein.

      • Enthält am Anfang eines Requests die Requestparameter vom User

      • Kann zwar intern über Requestgrenzen ein Datenbankhandle @@ -110,7 +110,7 @@ push @{ $form->{TEMPLATE_ARRAYS}{number} }, $form->{"partnumber_$i"}; push @{ $form->{TEMPLATE_ARRAYS}{description} }, $form->{"description_$i"}; # ... -}

      4.1.3.2. %::myconfig

      • Das einzige Hash unter den globalen Variablen

      • Wird spätestens benötigt wenn auf die Datenbank +}

      4.1.3.2. %::myconfig

      • Das einzige Hash unter den globalen Variablen

      • Wird spätestens benötigt wenn auf die Datenbank zugegriffen wird

      • Wird bei jedem Request neu erstellt.

      • Enthält die Userdaten des aktuellen Logins

      • Sollte nicht ohne Filterung irgendwo gedumpt werden oder extern serialisiert werden, weil da auch der Datenbankzugriff für diesen user drinsteht.

      • Enthält unter anderem Listenbegrenzung vclimit, @@ -122,10 +122,10 @@ überwiegend die Daten, die sich unter Programm -> Einstellungen befinden, bzw. die Informationen über den Benutzer die über die - Administrator-Schnittstelle (admin.pl) eingegeben wurden.

      4.1.3.3. $::locale

      • Objekt der Klasse "Locale"

      • Wird pro Request erstellt

      • Muss auch für Tests und Scripte immer verfügbar + Administrator-Schnittstelle (admin.pl) eingegeben wurden.

      4.1.3.3. $::locale

      • Objekt der Klasse "Locale"

      • Wird pro Request erstellt

      • Muss auch für Tests und Scripte immer verfügbar sein.

      • Cached intern über Requestgrenzen hinweg benutzte Locales

      Lokalisierung für den aktuellen User. Alle Übersetzungen, - Zahlen- und Datumsformatierungen laufen über dieses Objekt.

      4.1.3.4. $::lxdebug

      • Objekt der Klasse "LXDebug"

      • Wird global gecached

      • Muss immer verfügbar sein, in nahezu allen + Zahlen- und Datumsformatierungen laufen über dieses Objekt.

      4.1.3.4. $::lxdebug

      • Objekt der Klasse "LXDebug"

      • Wird global gecached

      • Muss immer verfügbar sein, in nahezu allen Funktionen

      $::lxdebug stellt Debuggingfunktionen bereit, wie "enter_sub" und @@ -135,12 +135,12 @@ "message" und "dump" mit denen man flott Informationen ins Log (tmp/kivitendo-debug.log) packen kann.

      Beispielsweise so:

      $main::lxdebug->message(0, 'Meine Konfig:' . Dumper (%::myconfig));
      -$main::lxdebug->message(0, 'Wer bin ich? Kunde oder Lieferant:' . $form->{vc});

      4.1.3.5. $::auth

      • Objekt der Klasse "SL::Auth"

      • Wird global gecached

      • Hat eine permanente DB Verbindung zur Authdatenbank

      • Wird nach jedem Request resettet.

      +$main::lxdebug->message(0, 'Wer bin ich? Kunde oder Lieferant:' . $form->{vc});

      4.1.3.5. $::auth

      • Objekt der Klasse "SL::Auth"

      • Wird global gecached

      • Hat eine permanente DB Verbindung zur Authdatenbank

      • Wird nach jedem Request resettet.

      $::auth stellt Funktionen bereit um die Rechte des aktuellen Users abzufragen. Obwohl diese Informationen vom aktuellen User abhängen wird das Objekt aus Geschwindigkeitsgründen nur einmal angelegt und dann nach jedem - Request kurz resettet.

      4.1.3.6. $::lx_office_conf

      • Objekt der Klasse + Request kurz resettet.

      4.1.3.6. $::lx_office_conf

      • Objekt der Klasse "SL::LxOfficeConf"

      • Global gecached

      • Repräsentation der config/kivitendo.conf[.default]-Dateien

      Globale Konfiguration. Configdateien werden zum Start gelesen und danach nicht mehr angefasst. Es ist derzeit nicht geplant, dass @@ -150,16 +150,16 @@ $main::lxdebug->message(0, 'Wer bin ich? Kunde oder Lieferant:' . $form->{ file = /tmp/kivitendo-debug.log

      ist der Key file im Programm als $::lx_office_conf->{debug}{file} erreichbar.

      [Warnung]Warnung

      Zugriff auf die Konfiguration erfolgt im Moment über - Hashkeys, sind also nicht gegen Tippfehler abgesichert.

      4.1.3.7. $::instance_conf

      • Objekt der Klasse + Hashkeys, sind also nicht gegen Tippfehler abgesichert.

    4.1.3.7. $::instance_conf

    • Objekt der Klasse "SL::InstanceConfiguration"

    • wird pro Request neu erstellt

    Funktioniert wie $::lx_office_conf, speichert aber Daten die von der Instanz abhängig sind. Eine Instanz ist hier eine Mandantendatenbank. Beispielsweise überprüft

    $::instance_conf->get_inventory_system eq 'perpetual'

    - ob die berüchtigte Bestandsmethode zur Anwendung kommt.

    4.1.3.8. $::dispatcher

    • Objekt der Klasse + ob die berüchtigte Bestandsmethode zur Anwendung kommt.

    4.1.3.8. $::dispatcher

    • Objekt der Klasse "SL::Dispatcher"

    • wird pro Serverprozess erstellt.

    • enthält Informationen über die technische Verbindung zum Server

    Der dritte Punkt ist auch der einzige Grund warum das Objekt global gespeichert wird. Wird vermutlich irgendwann in einem anderen - Objekt untergebracht.

    4.1.3.9. $::request

    • Hashref (evtl später Objekt)

    • Wird pro Request neu initialisiert.

    • Keine Unterstruktur garantiert.

    + Objekt untergebracht.

    4.1.3.9. $::request

    • Hashref (evtl später Objekt)

    • Wird pro Request neu initialisiert.

    • Keine Unterstruktur garantiert.

    $::request ist ein generischer Platz um Daten "für den aktuellen Request" abzulegen. Sollte nicht für action at a distance benutzt werden, sondern um lokales memoizing zu @@ -172,20 +172,20 @@ file = /tmp/kivitendo-debug.log

    ist der Key file$::request

  • Muss ich von anderen Teilen des Programms lesend drauf zugreifen? Dann $::request, aber Zugriff über - Wrappermethode

  • 4.1.4. Ehemalige globale Variablen

    Die folgenden Variablen waren einmal im Programm, und wurden - entfernt.

    4.1.4.1. $::cgi

    • war nötig, weil cookie Methoden nicht als + Wrappermethode

    4.1.4. Ehemalige globale Variablen

    Die folgenden Variablen waren einmal im Programm, und wurden + entfernt.

    4.1.4.1. $::cgi

    • war nötig, weil cookie Methoden nicht als Klassenfunktionen funktionieren

    • Aufruf als Klasse erzeugt Dummyobjekt was im Klassennamespace gehalten wird und über Requestgrenzen leaked

    • liegt jetzt unter $::request->{cgi} -

    4.1.4.2. $::all_units

    • war nötig, weil einige Funktionen in Schleifen zum Teil +

    4.1.4.2. $::all_units

    • war nötig, weil einige Funktionen in Schleifen zum Teil ein paar hundert mal pro Request eine Liste der Einheiten brauchen, und de als Parameter durch einen Riesenstack von Funktionen geschleift werden müssten.

    • Liegt jetzt unter $::request->{cache}{all_units}

    • Wird nur in AM->retrieve_all_units() gesetzt oder - gelesen.

    4.1.4.3. %::called_subs

    • wurde benutzt um callsub deep recursions + gelesen.

    4.1.4.3. %::called_subs

    • wurde benutzt um callsub deep recursions abzufangen.

    • Wurde entfernt, weil callsub nur einen Bruchteil der möglichen Rekursioenen darstellt, und da nie welche auftreten.

    • komplette recursion protection wurde entfernt.

    \ No newline at end of file diff --git a/doc/html/ch04s04.html b/doc/html/ch04s04.html index 84d9627fa..bae0cca0f 100644 --- a/doc/html/ch04s04.html +++ b/doc/html/ch04s04.html @@ -1,6 +1,6 @@ - 4.4. Translations and languages

    4.4. Translations and languages

    4.4.1. Introduction

    - + diff --git a/templates/webpages/client_config/form.html b/templates/webpages/client_config/form.html new file mode 100644 index 000000000..5fc0c04ac --- /dev/null +++ b/templates/webpages/client_config/form.html @@ -0,0 +1,189 @@ +[%- USE T8 %][%- USE L %][% USE LxERP %] + +

    [% title | html %]

    + +[% PROCESS 'common/flash.html' %] + + + +
    [Anmerkung]Anmerkung

    Dieser Abschnitt ist in Englisch geschrieben, um + 4.4. Translations and languages

    4.4. Translations and languages

    4.4.1. Introduction

    [Anmerkung]Anmerkung

    Dieser Abschnitt ist in Englisch geschrieben, um internationalen Übersetzern die Arbeit zu erleichtern.

    This section describes how localization packages in kivitendo are built. Currently the only language fully supported is German, and since most of the internal messages are held in English the English @@ -78,4 +78,4 @@ filenames

    The last of which is very machine dependant. Remember that case you made a typo, so that you don't have to translate everything again. If a tranlsation is missing, the lost file is checked first. If you maintain a language package, you might - want to keep this safe somewhere.

    \ No newline at end of file + want to keep this safe somewhere.

    \ No newline at end of file diff --git a/doc/html/ch04s05.html b/doc/html/ch04s05.html index 9d3743f07..87fee7702 100644 --- a/doc/html/ch04s05.html +++ b/doc/html/ch04s05.html @@ -1,120 +1,41 @@ - 4.5. Stil-Richtlinien

    4.5. Stil-Richtlinien

    Die folgenden Regeln haben das Ziel, den Code möglichst gut les- - und wartbar zu machen. Dazu gehört zum Einen, dass der Code einheitlich - eingerückt ist, aber auch, dass Mehrdeutigkeit so weit es geht vermieden - wird (Stichworte "Klammern" oder "Hash-Keys").

    Diese Regeln sind keine Schikane sondern erleichtern allen das - Leben!

    Jeder, der einen Patch schickt, sollte seinen Code vorher - überprüfen. Einige der Regeln lassen sich automatisch überprüfen, andere - nicht.

    1. Es werden keine echten Tabs sondern Leerzeichen - verwendet.

    2. Die Einrückung beträgt zwei Leerzeichen. Beispiel:

      foreach my $row (@data) {
      -  if ($flag) {
      -    # do something with $row
      -  }
      +   4.5. Die kivitendo-Test-Suite

      4.5. Die kivitendo-Test-Suite

      4.5.1. Einführung

      kivitendo enthält eine Suite für automatisierte Tests. Sie basiert auf dem Standard-Perl-Modul Test::More.

      Die grundlegenden Fakten sind:

      • Alle Tests liegen im Unterverzeichnis t/.

      • Ein Script (bzw. ein Test) in f/ enthält einen oder mehrere Testfälle.

      • Alle Dateinamen von Tests enden auf .t. Es sind selbstständig ausführbare Perl-Scripte.

      • Die Test-Suite besteht aus der Gesamtheit aller Tests, sprich aller Scripte in f/, deren + Dateiname auf .t endet.

      4.5.2. Voraussetzungen

      Für die Ausführung werden neben den für kivitendo eh schon benötigten Module noch weitere Perl-Module benötigt. Diese sind:

      • + Test::Deep (Debian-Paketname: libtest-deep-perl; Fedora Core: + perl-Test-Deep; openSuSE: perl-Test-Deep)

      4.5.3. + Existierende Tests ausführen +

      Es gibt mehrere Möglichkeiten zum Ausführen der Tests: entweder, man lässt alle Tests auf einmal ausführen, oder man führt + gezielt einzelne Scripte aus. Für beide Fälle gibt es das Helferscript t/test.sh.

      Will man die komplette Test-Suite ausführen, so muss man einfach nur t/test.sh ohne weitere Parameter aus + dem kivitendo-Basisverzeichnis heraus ausführen.

      Um einzelne Test-Scripte auszuführen, übergibt man deren Namen an t/test.sh. Beispielsweise:

      t/test.sh t/form/format_amount.t t/background_job/known_jobs.t

      4.5.4. + Bedeutung der verschiedenen Test-Scripte +

      Die Test-Suite umfasst Tests sowohl für Funktionen als auch für Programmierstil. Einige besonders zu erwähnende, weil auch + während der Entwicklung nützliche Tests sind:

      • + t/001compile.t -- compiliert alle Quelldateien und bricht bei Fehlern sofort ab

      • + t/002goodperl.t -- überprüft alle Perl-Dateien auf Anwesenheit von 'use strict'-Anweisungen

      • + t/003safesys.t -- überprüft Aufrufe von system() und exec() auf Gültigkeit

      • + t/005no_tabs.t -- überprüft, ob Dateien Tab-Zeichen enthalten

      • + t/006spelling.t -- sucht nach häufigen Rechtschreibfehlern

      • + t/011pod.t -- überprüft die Syntax von Dokumentation im POD-Format auf Gültigkeit

      Weitere Test-Scripte überprüfen primär die Funktionsweise einzelner Funktionen und Module.

      4.5.5. + Neue Test-Scripte erstellen +

      Es wird sehr gern gesehen, wenn neue Funktionalität auch gleich mit einem Test-Script abgesichert wird. Auch bestehende + Funktion darf und soll ausdrücklich nachträglich mit Test-Scripten abgesichert werden.

      4.5.5.1. + Ideen für neue Test-Scripte, die keine konkreten Funktionen testen +

      Ideen, die abgesehen von Funktions noch nicht umgesetzt wurden:

      • Überprüfung auf fehlende symbolische Links

      • Suche nach Nicht-ASCII-Zeichen in Perl-Code-Dateien (mit gewissen Einschränkungen wie das Erlauben von deutschen Umlauten)

      • Test auf DOS-Zeilenenden (\r\n anstelle von nur \n)

      • Überprüfung auf Leerzeichen am Ende von Zeilen

      • Test, ob alle zu übersetzenden Strings in locale/de/all vorhanden sind

      • Test, ob alle Webseiten-Templates in templates/webpages mit vom Perl-Modul Template compiliert werden können

      4.5.5.2. + Konvention für Verzeichnis- und Dateinamen +

      Es gibt momentan eine wenige Richtlinien, wie Test-Scripte zu benennen sind. Bitte die folgenden Punkte als Richtlinie betrachten und ihnen soweit es geht folgen:

      • Die Dateiendung muss .t lauten.

      • Namen sind englisch, komplett klein geschrieben und einzelne Wörter mit Unterstrichten getrennt (beispielsweise + bad_function_params.t).

      • Unterverzeichnisse sollten grob nach dem Themenbereich benannt sind, mit dem sich die Scripte darin befassen + (beispielsweise background_jobs für Tests rund um Hintergrund-Jobs).

      • Test-Scripte sollten einen überschaubaren Bereich von Funktionalität testen, der logisch zusammenhängend ist + (z.B. nur Tests für eine einzelne Funktion in einem Modul). Lieber mehrere Test-Scripte schreiben.

      4.5.5.3. + Minimales Skelett für eigene Scripte +

      Der folgenden Programmcode enthält das kleinstmögliche Testscript und kann als Ausgangspunkt für eigene Tests verwendet werden:

      use Test::More tests => 0;
       
      -  if ($use_modules) {
      -    $row->{modules} = MODULE->retrieve(
      -      id   => $row->{id},
      -      date => $use_now ? localtime() : $row->{time},
      -    );
      -  }
      +use lib 't';
       
      -  $report->add($row);
      -}
    3. Öffnende geschweifte Klammern befinden sich auf der gleichen - Zeile wie der letzte Befehl. Beispiele:

      sub debug {
      -  ...
      -}

      oder

      if ($form->{item_rows} > 0) {
      -  ...
      -}
    4. Schließende geschweifte Klammern sind so weit eingerückt wie - der Befehl / die öffnende schließende Klammer, die den Block - gestartet hat, und nicht auf der Ebene des Inhalts. Die gleichen - Beispiele wie bei 3. gelten.

    5. Die Wörter "else", - "elsif", "while" befinden - sich auf der gleichen Zeile wie schließende geschweifte Klammern. - Beispiele:

      if ($form->{sum} > 1000) {
      -  ...
      -} elsif ($form->{sum} > 0) {
      -  ...
      -} else {
      -  ...
      -}
      +use Support::TestSetup;
       
      -do {
      -  ...
      -} until ($a > 0);
    6. Parameter von Funktionsaufrufen müssen mit runden Klammern - versehen werden. Davon nicht betroffen sind interne Perl-Funktionen, - und grep-ähnliche Operatoren. Beispiel:

      $main::lxdebug->message("Could not find file.");
      -%options = map { $_ => 1 } grep { !/^#/ } @config_file;
    7. Verschiedene Klammern, Ihre Ausdrücke und Leerzeichen:

      Generell gilt: Hashkeys und Arrayindices sollten nicht durch - Leerzeichen abgesetzt werden. Logische Klammerungen ebensowenig, - Blöcke schon. Beispiel:

      if (($form->{debug} == 1) && ($form->{sum} - 100 < 0)) {
      -  ...
      -}
      -
      -$array[$i + 1]             = 4;
      -$form->{sum}              += $form->{"row_$i"};
      -$form->{ $form->{index} } += 1;
      -
      -map { $form->{sum} += $form->{"row_$_"} } 1..$rowcount;
    8. Mehrzeilige Befehle

      1. Werden die Parameter eines Funktionsaufrufes auf mehrere - Zeilen aufgeteilt, so sollten diese bis zu der Spalte eingerückt - werden, in der die ersten Funktionsparameter in der ersten Zeile - stehen. Beispiel:

        $sth = $dbh->prepare("SELECT * FROM some_table WHERE col = ?",
        -                    $form->{some_col_value});
      2. Ein Spezialfall ist der ternäre Oprator "?:", der am - besten in einer übersichtlichen Tabellenstruktur organisiert - wird. Beispiel:

        my $rowcount = $form->{"row_$i"} ? $i
        -             : $form->{oldcount} ? $form->{oldcount} + 1
        -             :                     $form->{rowcount} - $form->{rowbase};
    9. Kommentare

      1. Kommentare, die alleine in einer Zeile stehen, sollten - soweit wie der Code eingerückt sein.

      2. Seitliche hängende Kommentare sollten einheitlich - formatiert werden.

      3. Sämtliche Kommentare und Sonstiges im Quellcode ist bitte - auf Englisch zu verfassen. So wie ich keine Lust habe, - französischen Quelltext zu lesen, sollte auch der kivitendo - Quelltext für nicht-Deutschsprachige lesbar sein. - Beispiel:

        my $found = 0;
        -while (1) {
        -  last if $found;
        -
        -  # complicated check
        -  $found = 1 if //
        -}
        -
        -$i  = 0        # initialize $i
        -$n  = $i;      # save $i
        -$i *= $const;  # do something crazy
        -$i  = $n;      # recover $i
    10. Hashkeys sollten nur in Anführungszeichen stehen, wenn die - Interpolation gewünscht ist. Beispiel:

      $form->{sum}      = 0;
      -$form->{"row_$i"} = $form->{"row_$i"} - 5;
      -$some_hash{42}    = 54;
    11. Die maximale Zeilenlänge ist nicht beschränkt. Zeilenlängen - unterhalb von 79 Zeichen helfen unter bestimmten Bedingungen, aber - wenn die Lesbarkeit unter kurzen Zeilen leidet (wie zum Biespiel in - grossen Tabellen), dann ist Lesbarkeit vorzuziehen.

      Als Beispiel sei die Funktion - print_options aus - bin/mozilla/io.pl angeführt.

    12. Trailing Whitespace, d.h. Leerzeichen am Ende von Zeilen sind - unerwünscht. Sie führen zu unnötigen Whitespaceänderungen, die diffs - verfälschen.

      Emacs und vim haben beide recht einfache Methoden zur - Entfernung von trailing whitespace. Emacs kennt das Kommande - nuke-trailing-whitespace, vim macht das gleiche - manuell über :%s/\s\+$//e Mit :au - BufWritePre * :%s/\s\+$//e wird das an Speichern - gebunden.

    13. Es wird kein perltidy verwendet.

      In der Vergangenheit wurde versucht, - perltidy zu verwenden, um einen einheitlichen - Stil zu erlangen. Es hat sich aber gezeigt, dass - perltidys sehr eigenwilliges Verhalten, was - Zeilenumbrüche angeht, oftmals gut formatierten Code zerstört. Für - den Interessierten sind hier die - perltidy-Optionen, die grob den beschriebenen - Richtlinien entsprechen:

      -syn -i=2 -nt -pt=2 -sbt=2 -ci=2 -ibc -hsc -noll -nsts -nsfs -asc -dsm
      --aws -bbc -bbs -bbb -mbl=1 -nsob -ce -nbl -nsbl -cti=0 -bbt=0 -bar -l=79
      --lp -vt=1 -vtc=1
    14. - STDERR ist tabu. Unkonditionale - Debugmeldungen auch.

      kivitendo bietet mit dem Modul LXDebug - einen brauchbaren Trace-/Debug-Mechanismus. Es gibt also keinen - Grund, nach STDERR zu schreiben.

      Die LXDebug-Methode - "message" nimmt als ersten Paramter außerdem - eine Flagmaske, für die die Meldung angezeigt wird, wobei "0" immer - angezeigt wird. Solche Meldungen sollten nicht eingecheckt werden - und werden in den meisten Fällen auch vom Repository - zurückgewiesen.

    15. Alle neuen Module müssen use strict verwenden.

      - $form, $auth, - $locale, $lxdebug und - %myconfig werden derzeit aus dem main package - importiert (siehe Globale Variablen. Alle anderen - Konstrukte sollten lexikalisch lokal gehalten werden.

    \ No newline at end of file +Support::TestSetup::login();

    Wird eine vollständig initialisierte kivitendo-Umgebung benötigt (Stichwort: alle globalen Variablen wie + $::auth, $::form oder $::lxdebug), so muss in der Konfigurationsdatei + config/kivitendo.conf im Abschnitt testing.login ein gültiger Login-Name eingetragen + sein. Dieser wird für die Datenbankverbindung benötigt.

    Wir keine vollständig initialisierte Umgebung benötigt, so kann die letzte Zeile Support::TestSetup::login(); + weggelassen werden, was die Ausführungszeit des Scripts leicht verringert.

    \ No newline at end of file diff --git a/doc/html/ch04s06.html b/doc/html/ch04s06.html index e99f3e0d1..a5580b2ea 100644 --- a/doc/html/ch04s06.html +++ b/doc/html/ch04s06.html @@ -1,38 +1,120 @@ - 4.6. Dokumentation erstellen

    4.6. Dokumentation erstellen

    4.6.1. Einführung

    Diese Dokumentation ist in DocBook™ - XML geschrieben. Zum Bearbeiten reicht grundsätzlich ein Text-Editor. - Mehr Komfort bekommt man, wenn man einen dedizierten XML-fähigen - Editor nutzt, der spezielle Unterstützung für - DocBook™ mitbringt. Wir empfehlen dafür den - XMLmind XML - Editor, der bei nicht kommerzieller Nutzung kostenlos - ist.

    4.6.2. Benötigte Software

    Bei DocBook™ ist Prinzip, dass - ausschließlich die XML-Quelldatei bearbeitet wird. Aus dieser werden - dann mit entsprechenden Stylesheets andere Formate wie PDF oder HTML - erzeugt. Bei kivitendo übernimmt diese Aufgabe das Shell-Script - scripts/build_doc.sh.

    Das Script benötigt zur Konvertierung verschiedene - Softwarekomponenten, die im normalen kivitendo-Betrieb nicht benötigt - werden:

    • - Java - in einer halbwegs aktuellen Version

    • Das Java-Build-System Apache Ant -

    • Das Dokumentations-System Dobudish für - DocBook™ 4.5, eine Zusammenstellung - diverser Stylesheets und Grafiken zur Konvertierung von - DocBook™ XML in andere Formate. Das - Paket, das benötigt wird, ist zum Zeitpunkt der - Dokumentationserstellung - dobudish-nojre-1.1.4.zip, aus auf code.google.com - bereitsteht.

    Apache Ant sowie ein dazu passendes Java Runtime Environment - sind auf allen gängigen Plattformen verfügbar. Beispiel für - Debian/Ubuntu:

    apt-get install ant openjdk-7-jre

    Nach dem Download von Dobudish muss Dobudish im Unterverzeichnis - doc/build entpackt werden. Beispiel unter der - Annahme, das Dobudish™ in - $HOME/Downloads heruntergeladen wurde:

    cd doc/build
    -unzip $HOME/Downloads/dobudish-nojre-1.1.4.zip

    4.6.3. PDFs und HTML-Seiten erstellen

    Die eigentliche Konvertierung erfolgt nach Installation der - benötigten Software mit einem einfachen Aufruf direkt aus dem - kivitendo-Installationsverzeichnis heraus:

    ./scripts/build_doc.sh

    4.6.4. Einchecken in das Git-Repository

    Sowohl die XML-Datei als auch die erzeugten PDF- und - HTML-Dateien sind Bestandteil des Git-Repositories. Daraus folgt, dass - nach Änderungen am XML die PDF- und HTML-Dokumente ebenfalls gebaut - und alles zusammen in einem Commit eingecheckt werden sollten.

    Die "dobudish"-Verzeichnisse bzw. - symbolischen Links gehören hingegen nicht in das Repository.

    \ No newline at end of file + 4.6. Stil-Richtlinien

    4.6. Stil-Richtlinien

    Die folgenden Regeln haben das Ziel, den Code möglichst gut les- + und wartbar zu machen. Dazu gehört zum Einen, dass der Code einheitlich + eingerückt ist, aber auch, dass Mehrdeutigkeit so weit es geht vermieden + wird (Stichworte "Klammern" oder "Hash-Keys").

    Diese Regeln sind keine Schikane sondern erleichtern allen das + Leben!

    Jeder, der einen Patch schickt, sollte seinen Code vorher + überprüfen. Einige der Regeln lassen sich automatisch überprüfen, andere + nicht.

    1. Es werden keine echten Tabs sondern Leerzeichen + verwendet.

    2. Die Einrückung beträgt zwei Leerzeichen. Beispiel:

      foreach my $row (@data) {
      +  if ($flag) {
      +    # do something with $row
      +  }
      +
      +  if ($use_modules) {
      +    $row->{modules} = MODULE->retrieve(
      +      id   => $row->{id},
      +      date => $use_now ? localtime() : $row->{time},
      +    );
      +  }
      +
      +  $report->add($row);
      +}
    3. Öffnende geschweifte Klammern befinden sich auf der gleichen + Zeile wie der letzte Befehl. Beispiele:

      sub debug {
      +  ...
      +}

      oder

      if ($form->{item_rows} > 0) {
      +  ...
      +}
    4. Schließende geschweifte Klammern sind so weit eingerückt wie + der Befehl / die öffnende schließende Klammer, die den Block + gestartet hat, und nicht auf der Ebene des Inhalts. Die gleichen + Beispiele wie bei 3. gelten.

    5. Die Wörter "else", + "elsif", "while" befinden + sich auf der gleichen Zeile wie schließende geschweifte Klammern. + Beispiele:

      if ($form->{sum} > 1000) {
      +  ...
      +} elsif ($form->{sum} > 0) {
      +  ...
      +} else {
      +  ...
      +}
      +
      +do {
      +  ...
      +} until ($a > 0);
    6. Parameter von Funktionsaufrufen müssen mit runden Klammern + versehen werden. Davon nicht betroffen sind interne Perl-Funktionen, + und grep-ähnliche Operatoren. Beispiel:

      $main::lxdebug->message("Could not find file.");
      +%options = map { $_ => 1 } grep { !/^#/ } @config_file;
    7. Verschiedene Klammern, Ihre Ausdrücke und Leerzeichen:

      Generell gilt: Hashkeys und Arrayindices sollten nicht durch + Leerzeichen abgesetzt werden. Logische Klammerungen ebensowenig, + Blöcke schon. Beispiel:

      if (($form->{debug} == 1) && ($form->{sum} - 100 < 0)) {
      +  ...
      +}
      +
      +$array[$i + 1]             = 4;
      +$form->{sum}              += $form->{"row_$i"};
      +$form->{ $form->{index} } += 1;
      +
      +map { $form->{sum} += $form->{"row_$_"} } 1..$rowcount;
    8. Mehrzeilige Befehle

      1. Werden die Parameter eines Funktionsaufrufes auf mehrere + Zeilen aufgeteilt, so sollten diese bis zu der Spalte eingerückt + werden, in der die ersten Funktionsparameter in der ersten Zeile + stehen. Beispiel:

        $sth = $dbh->prepare("SELECT * FROM some_table WHERE col = ?",
        +                    $form->{some_col_value});
      2. Ein Spezialfall ist der ternäre Oprator "?:", der am + besten in einer übersichtlichen Tabellenstruktur organisiert + wird. Beispiel:

        my $rowcount = $form->{"row_$i"} ? $i
        +             : $form->{oldcount} ? $form->{oldcount} + 1
        +             :                     $form->{rowcount} - $form->{rowbase};
    9. Kommentare

      1. Kommentare, die alleine in einer Zeile stehen, sollten + soweit wie der Code eingerückt sein.

      2. Seitliche hängende Kommentare sollten einheitlich + formatiert werden.

      3. Sämtliche Kommentare und Sonstiges im Quellcode ist bitte + auf Englisch zu verfassen. So wie ich keine Lust habe, + französischen Quelltext zu lesen, sollte auch der kivitendo + Quelltext für nicht-Deutschsprachige lesbar sein. + Beispiel:

        my $found = 0;
        +while (1) {
        +  last if $found;
        +
        +  # complicated check
        +  $found = 1 if //
        +}
        +
        +$i  = 0        # initialize $i
        +$n  = $i;      # save $i
        +$i *= $const;  # do something crazy
        +$i  = $n;      # recover $i
    10. Hashkeys sollten nur in Anführungszeichen stehen, wenn die + Interpolation gewünscht ist. Beispiel:

      $form->{sum}      = 0;
      +$form->{"row_$i"} = $form->{"row_$i"} - 5;
      +$some_hash{42}    = 54;
    11. Die maximale Zeilenlänge ist nicht beschränkt. Zeilenlängen + unterhalb von 79 Zeichen helfen unter bestimmten Bedingungen, aber + wenn die Lesbarkeit unter kurzen Zeilen leidet (wie zum Biespiel in + grossen Tabellen), dann ist Lesbarkeit vorzuziehen.

      Als Beispiel sei die Funktion + print_options aus + bin/mozilla/io.pl angeführt.

    12. Trailing Whitespace, d.h. Leerzeichen am Ende von Zeilen sind + unerwünscht. Sie führen zu unnötigen Whitespaceänderungen, die diffs + verfälschen.

      Emacs und vim haben beide recht einfache Methoden zur + Entfernung von trailing whitespace. Emacs kennt das Kommande + nuke-trailing-whitespace, vim macht das gleiche + manuell über :%s/\s\+$//e Mit :au + BufWritePre * :%s/\s\+$//e wird das an Speichern + gebunden.

    13. Es wird kein perltidy verwendet.

      In der Vergangenheit wurde versucht, + perltidy zu verwenden, um einen einheitlichen + Stil zu erlangen. Es hat sich aber gezeigt, dass + perltidys sehr eigenwilliges Verhalten, was + Zeilenumbrüche angeht, oftmals gut formatierten Code zerstört. Für + den Interessierten sind hier die + perltidy-Optionen, die grob den beschriebenen + Richtlinien entsprechen:

      -syn -i=2 -nt -pt=2 -sbt=2 -ci=2 -ibc -hsc -noll -nsts -nsfs -asc -dsm
      +-aws -bbc -bbs -bbb -mbl=1 -nsob -ce -nbl -nsbl -cti=0 -bbt=0 -bar -l=79
      +-lp -vt=1 -vtc=1
    14. + STDERR ist tabu. Unkonditionale + Debugmeldungen auch.

      kivitendo bietet mit dem Modul LXDebug + einen brauchbaren Trace-/Debug-Mechanismus. Es gibt also keinen + Grund, nach STDERR zu schreiben.

      Die LXDebug-Methode + "message" nimmt als ersten Paramter außerdem + eine Flagmaske, für die die Meldung angezeigt wird, wobei "0" immer + angezeigt wird. Solche Meldungen sollten nicht eingecheckt werden + und werden in den meisten Fällen auch vom Repository + zurückgewiesen.

    15. Alle neuen Module müssen use strict verwenden.

      + $form, $auth, + $locale, $lxdebug und + %myconfig werden derzeit aus dem main package + importiert (siehe Globale Variablen. Alle anderen + Konstrukte sollten lexikalisch lokal gehalten werden.

    \ No newline at end of file diff --git a/doc/html/ch04s07.html b/doc/html/ch04s07.html new file mode 100644 index 000000000..0727e304c --- /dev/null +++ b/doc/html/ch04s07.html @@ -0,0 +1,38 @@ + + + 4.7. Dokumentation erstellen

    4.7. Dokumentation erstellen

    4.7.1. Einführung

    Diese Dokumentation ist in DocBook™ + XML geschrieben. Zum Bearbeiten reicht grundsätzlich ein Text-Editor. + Mehr Komfort bekommt man, wenn man einen dedizierten XML-fähigen + Editor nutzt, der spezielle Unterstützung für + DocBook™ mitbringt. Wir empfehlen dafür den + XMLmind XML + Editor, der bei nicht kommerzieller Nutzung kostenlos + ist.

    4.7.2. Benötigte Software

    Bei DocBook™ ist Prinzip, dass + ausschließlich die XML-Quelldatei bearbeitet wird. Aus dieser werden + dann mit entsprechenden Stylesheets andere Formate wie PDF oder HTML + erzeugt. Bei kivitendo übernimmt diese Aufgabe das Shell-Script + scripts/build_doc.sh.

    Das Script benötigt zur Konvertierung verschiedene + Softwarekomponenten, die im normalen kivitendo-Betrieb nicht benötigt + werden:

    • + Java + in einer halbwegs aktuellen Version

    • Das Java-Build-System Apache Ant +

    • Das Dokumentations-System Dobudish für + DocBook™ 4.5, eine Zusammenstellung + diverser Stylesheets und Grafiken zur Konvertierung von + DocBook™ XML in andere Formate. Das + Paket, das benötigt wird, ist zum Zeitpunkt der + Dokumentationserstellung + dobudish-nojre-1.1.4.zip, aus auf code.google.com + bereitsteht.

    Apache Ant sowie ein dazu passendes Java Runtime Environment + sind auf allen gängigen Plattformen verfügbar. Beispiel für + Debian/Ubuntu:

    apt-get install ant openjdk-7-jre

    Nach dem Download von Dobudish muss Dobudish im Unterverzeichnis + doc/build entpackt werden. Beispiel unter der + Annahme, das Dobudish™ in + $HOME/Downloads heruntergeladen wurde:

    cd doc/build
    +unzip $HOME/Downloads/dobudish-nojre-1.1.4.zip

    4.7.3. PDFs und HTML-Seiten erstellen

    Die eigentliche Konvertierung erfolgt nach Installation der + benötigten Software mit einem einfachen Aufruf direkt aus dem + kivitendo-Installationsverzeichnis heraus:

    ./scripts/build_doc.sh

    4.7.4. Einchecken in das Git-Repository

    Sowohl die XML-Datei als auch die erzeugten PDF- und + HTML-Dateien sind Bestandteil des Git-Repositories. Daraus folgt, dass + nach Änderungen am XML die PDF- und HTML-Dokumente ebenfalls gebaut + und alles zusammen in einem Commit eingecheckt werden sollten.

    Die "dobudish"-Verzeichnisse bzw. + symbolischen Links gehören hingegen nicht in das Repository.

    \ No newline at end of file diff --git a/doc/html/index.html b/doc/html/index.html index 827e6712d..b209b7830 100644 --- a/doc/html/index.html +++ b/doc/html/index.html @@ -1,6 +1,12 @@ - kivitendo: Installation, Konfiguration, Entwicklung

    kivitendo: Installation, Konfiguration, Entwicklung


    Inhaltsverzeichnis

    1. Aktuelle Hinweise
    2. Installation und Grundkonfiguration
    2.1. Benötigte Software und Pakete
    2.1.1. Betriebssystem
    2.1.2. Pakete
    2.2. Manuelle Installation des Programmpaketes
    2.3. kivitendo-Konfigurationsdatei
    2.3.1. Einführung
    2.3.2. Abschnitte und Parameter
    2.3.3. Versionen vor 2.6.3
    2.4. Anpassung der PostgreSQL-Konfiguration
    2.4.1. Zeichensätze/die Verwendung von UTF-8
    2.4.2. Änderungen an Konfigurationsdateien
    2.4.3. Erweiterung für servergespeicherte Prozeduren
    2.4.4. Datenbankbenutzer anlegen
    2.5. Webserver-Konfiguration
    2.5.1. Grundkonfiguration mittels CGI
    2.5.2. Konfiguration für FastCGI/FCGI
    2.6. Der Task-Server
    2.6.1. Verfügbare und notwendige Konfigurationsoptionen
    2.6.2. Automatisches Starten des Task-Servers beim Booten
    2.6.3. Wie der Task-Server gestartet und beendet wird
    2.6.4. Task-Server mit mehreren Mandanten
    2.7. Benutzerauthentifizierung und Administratorpasswort
    2.7.1. Grundlagen zur Benutzerauthentifizierung
    2.7.2. Administratorpasswort
    2.7.3. Authentifizierungsdatenbank
    2.7.4. Passwortüberprüfung
    2.7.5. Name des Session-Cookies
    2.7.6. Anlegen der Authentifizierungsdatenbank
    2.8. Benutzer- und Gruppenverwaltung
    2.8.1. Zusammenhänge
    2.8.2. Datenbanken anlegen
    2.8.3. Gruppen anlegen
    2.8.4. Benutzer anlegen
    2.8.5. Gruppenmitgliedschaften verwalten
    2.8.6. Migration alter Installationen
    2.9. Drucken mit kivitendo
    2.10. OpenDocument-Vorlagen
    2.11. Konfiguration zur Einnahmenüberschussrechnung/Bilanzierung: - EUR
    2.11.1. Einführung
    2.11.2. Konfigurationsparameter
    2.11.3. Festlegen der Parameter
    2.11.4. Bemerkungen zu Bestandsmethode
    2.11.5. Bekannte Probleme
    2.12. SKR04 19% Umstellung für innergemeinschaftlichen Erwerb
    2.12.1. Einführung
    2.12.2. Konto 3804 manuell anlegen
    2.13. kivitendo ERP verwenden
    3. Features und Funktionen
    3.1. Wiederkehrende Rechnungen
    3.1.1. Einführung
    3.1.2. Konfiguration
    3.1.3. Auflisten
    3.1.4. Erzeugung der eigentlichen Rechnungen
    3.1.5. Erste Rechnung für aktuellen Monat erstellen
    3.2. Dokumentenvorlagen und verfügbare Variablen
    3.2.1. Einführung
    3.2.2. Variablen ausgeben
    3.2.3. Verwendung in Druckbefehlen
    3.2.4. Anfang und Ende der Tags verändern
    3.2.5. Zuordnung von den Dateinamen zu den Funktionen
    3.2.6. Sprache, Drucker und E-Mail
    3.2.7. Allgemeine Variablen, die in allen Vorlagen vorhanden + kivitendo: Installation, Konfiguration, Entwicklung

    kivitendo: Installation, Konfiguration, Entwicklung


    Inhaltsverzeichnis

    1. Aktuelle Hinweise
    2. Installation und Grundkonfiguration
    2.1. Benötigte Software und Pakete
    2.1.1. Betriebssystem
    2.1.2. Pakete
    2.2. Manuelle Installation des Programmpaketes
    2.3. kivitendo-Konfigurationsdatei
    2.3.1. Einführung
    2.3.2. Abschnitte und Parameter
    2.3.3. Versionen vor 2.6.3
    2.4. Anpassung der PostgreSQL-Konfiguration
    2.4.1. Zeichensätze/die Verwendung von UTF-8
    2.4.2. Änderungen an Konfigurationsdateien
    2.4.3. Erweiterung für servergespeicherte Prozeduren
    2.4.4. Datenbankbenutzer anlegen
    2.5. Webserver-Konfiguration
    2.5.1. Grundkonfiguration mittels CGI
    2.5.2. Konfiguration für FastCGI/FCGI
    2.6. Der Task-Server
    2.6.1. Verfügbare und notwendige Konfigurationsoptionen
    2.6.2. Automatisches Starten des Task-Servers beim Booten
    2.6.3. Wie der Task-Server gestartet und beendet wird
    2.6.4. Task-Server mit mehreren Mandanten
    2.7. Benutzerauthentifizierung und Administratorpasswort
    2.7.1. Grundlagen zur Benutzerauthentifizierung
    2.7.2. Administratorpasswort
    2.7.3. Authentifizierungsdatenbank
    2.7.4. Passwortüberprüfung
    2.7.5. Name des Session-Cookies
    2.7.6. Anlegen der Authentifizierungsdatenbank
    2.8. Benutzer- und Gruppenverwaltung
    2.8.1. Zusammenhänge
    2.8.2. Datenbanken anlegen
    2.8.3. Gruppen anlegen
    2.8.4. Benutzer anlegen
    2.8.5. Gruppenmitgliedschaften verwalten
    2.8.6. Migration alter Installationen
    2.9. E-Mail-Versand aus kivitendo heraus
    2.9.1. Versand über lokalen E-Mail-Server
    2.9.2. Versand über einen SMTP-Server
    2.10. Drucken mit kivitendo
    2.11. OpenDocument-Vorlagen
    2.12. Konfiguration zur Einnahmenüberschussrechnung/Bilanzierung: + EUR
    2.12.1. Einführung
    2.12.2. Konfigurationsparameter
    2.12.3. Festlegen der Parameter
    2.12.4. Bemerkungen zu Bestandsmethode
    2.12.5. Bekannte Probleme
    2.13. SKR04 19% Umstellung für innergemeinschaftlichen Erwerb
    2.13.1. Einführung
    2.13.2. Konto 3804 manuell anlegen
    2.14. kivitendo ERP verwenden
    3. Features und Funktionen
    3.1. Wiederkehrende Rechnungen
    3.1.1. Einführung
    3.1.2. Konfiguration
    3.1.3. Auflisten
    3.1.4. Erzeugung der eigentlichen Rechnungen
    3.1.5. Erste Rechnung für aktuellen Monat erstellen
    3.2. Dokumentenvorlagen und verfügbare Variablen
    3.2.1. Einführung
    3.2.2. Variablen ausgeben
    3.2.3. Verwendung in Druckbefehlen
    3.2.4. Anfang und Ende der Tags verändern
    3.2.5. Zuordnung von den Dateinamen zu den Funktionen
    3.2.6. Sprache, Drucker und E-Mail
    3.2.7. Allgemeine Variablen, die in allen Vorlagen vorhanden sind
    3.2.8. Variablen in Rechnungen
    3.2.9. Variablen in Mahnungen und Rechnungen über Mahngebühren
    3.2.10. Variablen in anderen Vorlagen
    3.2.11. Blöcke, bedingte Anweisungen und Schleifen
    3.2.12. Markup-Code zur Textformatierung innerhalb von - Formularen
    3.3. Excel-Vorlagen
    3.3.1. Zusammenfassung
    3.3.2. Bedienung
    3.3.3. Variablensyntax
    3.3.4. Einschränkungen
    4. Entwicklerdokumentation
    4.1. Globale Variablen
    4.1.1. Wie sehen globale Variablen in Perl aus?
    4.1.2. Warum sind globale Variablen ein Problem?
    4.1.3. Kanonische globale Variablen
    4.1.4. Ehemalige globale Variablen
    4.2. Entwicklung unter FastCGI
    4.2.1. Allgemeines
    4.2.2. Programmende und Ausnahmen
    4.2.3. Globale Variablen
    4.2.4. Performance und Statistiken
    4.2.5. Bekannte Probleme
    4.3. SQL-Upgradedateien
    4.3.1. Einführung
    4.3.2. Format der Kontrollinformationen
    4.3.3. Hilfsscript dbupgrade2_tool.pl
    4.4. Translations and languages
    4.4.1. Introduction
    4.4.2. File structure
    4.5. Stil-Richtlinien
    4.6. Dokumentation erstellen
    4.6.1. Einführung
    4.6.2. Benötigte Software
    4.6.3. PDFs und HTML-Seiten erstellen
    4.6.4. Einchecken in das Git-Repository
    \ No newline at end of file + Formularen
    3.3. Excel-Vorlagen
    3.3.1. Zusammenfassung
    3.3.2. Bedienung
    3.3.3. Variablensyntax
    3.3.4. Einschränkungen
    4. Entwicklerdokumentation
    4.1. Globale Variablen
    4.1.1. Wie sehen globale Variablen in Perl aus?
    4.1.2. Warum sind globale Variablen ein Problem?
    4.1.3. Kanonische globale Variablen
    4.1.4. Ehemalige globale Variablen
    4.2. Entwicklung unter FastCGI
    4.2.1. Allgemeines
    4.2.2. Programmende und Ausnahmen
    4.2.3. Globale Variablen
    4.2.4. Performance und Statistiken
    4.2.5. Bekannte Probleme
    4.3. SQL-Upgradedateien
    4.3.1. Einführung
    4.3.2. Format der Kontrollinformationen
    4.3.3. Hilfsscript dbupgrade2_tool.pl
    4.4. Translations and languages
    4.4.1. Introduction
    4.4.2. File structure
    4.5. Die kivitendo-Test-Suite
    4.5.1. Einführung
    4.5.2. Voraussetzungen
    4.5.3. + Existierende Tests ausführen +
    4.5.4. + Bedeutung der verschiedenen Test-Scripte +
    4.5.5. + Neue Test-Scripte erstellen +
    4.6. Stil-Richtlinien
    4.7. Dokumentation erstellen
    4.7.1. Einführung
    4.7.2. Benötigte Software
    4.7.3. PDFs und HTML-Seiten erstellen
    4.7.4. Einchecken in das Git-Repository
    \ No newline at end of file diff --git a/doc/kivitendo-Dokumentation.pdf b/doc/kivitendo-Dokumentation.pdf index af6c5acdf..9b9dfb545 100644 Binary files a/doc/kivitendo-Dokumentation.pdf and b/doc/kivitendo-Dokumentation.pdf differ diff --git a/locale/de/all b/locale/de/all index e6d9521f8..db5ff2c52 100644 --- a/locale/de/all +++ b/locale/de/all @@ -48,13 +48,17 @@ $self->{texts} = { 'AP Transaction Storno (one letter abbreviation)' => 'S', 'AP Transaction with Storno (abbreviation)' => 'K(S)', 'AP Transactions' => 'Kreditorenbuchungen', + 'AP transactions changeable' => 'Änderbarkeit von Kreditorenbuchungen', 'AP transactions with sales taxkeys and/or AR transactions with input taxkeys' => 'Kreditorenbuchungen mit Umsatzsteuer-Steuerschlüsseln und/oder Debitorenbuchungen mit Vorsteuer-Steuerschlüsseln', 'AR' => 'Verkauf', 'AR Aging' => 'Offene Forderungen', 'AR Transaction' => 'Debitorenbuchung', 'AR Transaction (abbreviation)' => 'D', 'AR Transactions' => 'Debitorenbuchungen', + 'AR transactions changeable' => 'Änderbarkeit von Debitorenbuchungen', 'ASSETS' => 'AKTIVA', + 'ATTENTION! If you enabled this feature you can not simply turn it off again without taking care that best_before fields are emptied in the database.' => 'ACHTUNG! Wenn Sie diese Einstellung aktivieren, dann können Sie sie später nicht ohne Weiteres deaktivieren, ohne dafür zu sorgen, dass die Felder der Mindeshaltbarkeitsdaten in der Datenbank leer gemacht werden.', + 'ATTENTION! You can not simply change it from periodic to perpetual once you started posting.' => 'ACHTUNG! Es kann nicht ohne Weiteres im laufenden Betrieb von der Aufwandsmethode zur Bestandsmethode gewechselt werden.', 'Abort' => 'Abbrechen', 'Abrechnungsnummer' => 'Abrechnungsnummer', 'Abteilung' => 'Abteilung', @@ -185,6 +189,7 @@ $self->{texts} = { 'An upper-case character is required.' => 'Ein Großbuchstabe ist vorgeschrieben.', 'Annotations' => 'Anmerkungen', 'Another user with the login #1 does already exist.' => 'Es existiert bereits ein anderer Benutzer mit diesem Login.', + 'Any stock contents containing a best before date will be impossible to stock out otherwise.' => 'Sonst können Artikel, bei denen ein Mindesthaltbarkeitsdatum gesetzt ist, nicht mehr ausgelagert werden.', 'Ap aging on %s' => 'Offene Verbindlichkeiten zum %s', 'Application Error. No Format given' => 'Fehler in der Anwendung. Das Ausgabeformat fehlt.', 'Application Error. Wrong Format' => 'Fehler in der Anwendung. Falsches Format: ', @@ -397,6 +402,11 @@ $self->{texts} = { 'Check' => 'Scheck', 'Check Details' => 'Bitte Angaben überprüfen', 'Check for duplicates' => 'Dublettencheck', + 'Check on ap transaction' => 'Prüfen bei Kreditorenbuchung', + 'Check on ar transaction' => 'Prüfen bei Debitorenbuchung', + 'Check on gl transaction' => 'Prüfen bei Dialogbuchung', + 'Check on purchase invoice' => 'Prüfen bei Einkaufsrechnung', + 'Check on sales invoice' => 'Prüfen bei Verkaufsrechnung', 'Checks' => 'Schecks', 'Choose Customer' => 'Endkunde wählen:', 'Choose Outputformat' => 'Ausgabeformat auswählen...', @@ -406,6 +416,8 @@ $self->{texts} = { 'Cleared Balance' => 'abgeschlossen', 'Clearing Tax Received (No 71)' => 'Verrechnung des Erstattungsbetrages erwünscht (Zeile 71)', 'Click on login name to edit!' => 'Zum Bearbeiten den Benutzernamen anklicken!', + 'Client Configuration' => 'Mandantenkonfiguration', + 'Client Configuration saved!' => 'Mandantenkonfiguration gespeichert!', 'Close' => 'Übernehmen', 'Close Books up to' => 'Die Bücher abschließen bis zum', 'Close Dialog' => 'Schließen', @@ -538,6 +550,7 @@ $self->{texts} = { 'DATEV - Export Assistent' => 'DATEV-Exportassistent', 'DATEV Angaben' => 'DATEV-Angaben', 'DATEV Export' => 'DATEV-Export', + 'DATEV check configuration' => 'Einstellungen für DATEV-Prüfung', 'DATEV check returned errors:' => 'Die DATEV Prüfung dieser Buchung ergab Fehler:', 'DATEX - Export Assistent' => 'DATEV-Exportassistent', 'DELETED' => 'Gelöscht', @@ -901,6 +914,7 @@ $self->{texts} = { 'Full access to all functions' => 'Vollzugriff auf alle Funktionen', 'Fwd' => 'Vorwärts', 'GL Transaction' => 'Dialogbuchung', + 'GL transactions changeable' => 'Änderbarkeit von Dialogbuchungen', 'Gegenkonto' => 'Gegenkonto', 'Gender' => 'Geschlecht', 'General Ledger' => 'Finanzbuchhaltung', @@ -1032,6 +1046,7 @@ $self->{texts} = { 'It is possible that even after such a correction there is something wrong with this transaction (e.g. taxes that don\'t match the selected taxkey). Therefore you should re-run the general ledger analysis.' => 'Auch nach einer Korrektur kann es mit dieser Buchung noch weitere Probleme geben (z.B. nicht zum Steuerschlüssel passende Steuern), weshalb ein erneutes Ausführen der Hauptbuchanalyse empfohlen wird.', 'It is possible to do this automatically for some Buchungsgruppen, but not for all.' => 'Es ist möglich, dies für einige, aber nicht für alle Buchungsgruppen automatisch zu erledigen.', 'It is possible to do this automatically for some units, but for others the user has to chose the new unit.' => 'Das ist für einige Einheiten automatisch möglich, aber bei anderen muss der Benutzer die neue Einheit auswählen.', + 'It is possible to make a quick DATEV export everytime you post a record to ensure things work nicely with their data requirements. This will result in a slight overhead though you can enable this for each type of record independantly.' => 'Es ist möglich, bei jeder Buchung einen schnellen DATEV-Export durchzuführen, um sicherzustellen, dass die Datensätze den DATEV-Anforderungen genügen. Da dies einen kleinen Overhead bedeutet, lässt sich die Einstellung für jeden Buchungstyp getrennt einstellen.', 'It may optionally be compressed with "gzip".' => 'Sie darf optional mit "gzip" komprimiert sein.', 'It will simply set the taxkey to 0 (meaning "no taxes") which is the correct value for such inventory transactions.' => 'Es wird einfach die Steuerschlüssel auf 0 setzen, was "keine Steuer" bedeutet und für solche Warenbestandsbuchungen der richtige Wert ist.', 'Item deleted!' => 'Artikel gelöscht!', @@ -1051,8 +1066,6 @@ $self->{texts} = { 'KNE-Export erfolgreich!' => 'KNE-Export erfolgreich!', 'KNr. beim Kunden' => 'KNr. beim Kunden', 'Keine Suchergebnisse gefunden!' => 'Keine Suchergebnisse gefunden!', - 'Kivitendo needs to update the authentication database before you can proceed.' => 'kivitendo muss die Authentifizierungsdatenbank aktualisieren, bevor Sie fortfahren können.', - 'Kivitendo will then update the database automatically.' => 'kivitendo wird die Datenbank daraufhin automatisch aktualisieren.', 'Konten' => 'Konten', 'L' => 'L', 'LIABILITIES' => 'PASSIVA', @@ -1130,7 +1143,6 @@ $self->{texts} = { 'Long Dates' => 'Lange Monatsnamen', 'Long Description' => 'Langtext', 'MAILED' => 'Gesendet', - 'MSG_BROWSER_DOES_NOT_SUPPORT_IFRAMES' => 'Ihr Browser kann leider keine eingebetteten Frames anzeigen. Bitte wählen Sie ein anderes Menü in der Benutzerkonfiguration im Administrationsmenü aus.', 'Main Preferences' => 'Grundeinstellungen', 'Main sorting' => 'Hauptsortierung', 'Make' => 'Lieferant', @@ -1317,6 +1329,7 @@ $self->{texts} = { 'Order Number missing!' => 'Auftragsnummer fehlt!', 'Order deleted!' => 'Auftrag gelöscht!', 'Ordered' => 'Vom Kunde bestellt', + 'Orders / Delivery Orders deleteable' => 'Aufträge / Lieferscheine löschbar', 'Orientation' => 'Seitenformat', 'Orphaned' => 'Nie benutzt', 'Other users\' follow-ups' => 'Wiedervorlagen anderer Benutzer', @@ -1372,7 +1385,13 @@ $self->{texts} = { 'Payment terms (database ID)' => 'Zahlungsbedingungen (Datenbank-ID)', 'Payment terms (name)' => 'Zahlungsbedingungen (Name)', 'Payments' => 'Zahlungsausgänge', + 'Payments Changeable' => 'Änderbarkeit von Zahlungen', 'Per. Inv.' => 'Wied. Rech.', + 'Perform check when a gl transaction is posted?' => 'Prüfung durchführen, wenn eine Dialogbuchung gebucht wird?', + 'Perform check when a purchase invoice or a payment for a purchase invoice is posted?' => 'Prüfung durchführen, wenn eine Einkaufsrechnung oder ein Zahlungsausgang hierfür gebucht wird?', + 'Perform check when a sales invoice or a payment for a sales invoice is posted?' => 'Prüfung durchführen, wenn eine Verkaufsrechnung oder ein Zahlungseingang hierfür gebucht wird?', + 'Perform check when an ap transaction is posted?' => 'Prüfung durchführen, wenn eine Kreditorenbuchung gebucht wird?', + 'Perform check when an ar transaction is posted?' => 'Prüfung durchführen, wenn eine Debiotorenbuchung gebucht wird?', 'Period' => 'Zeitraum', 'Period:' => 'Zeitraum:', 'Periodic Invoices' => 'Wiederkehrende Rechnungen', @@ -1420,6 +1439,7 @@ $self->{texts} = { 'Post' => 'Buchen', 'Post Payment' => 'Zahlung buchen', 'Post payments' => 'Zahlungen buchen', + 'Posting Configuration' => 'Buchungskonfiguration', 'Postscript' => 'Postscript', 'Posustva_coa' => 'USTVA Kennz.', 'Preferences' => 'Einstellungen', @@ -1481,13 +1501,16 @@ $self->{texts} = { 'Projects' => 'Projekte', 'Projecttransactions' => 'Projektbuchungen', 'Prozentual/Absolut' => 'Prozentual/Absolut', + 'Purchase Delivery Orders deleteable' => 'Einkaufslieferscheine löschbar', 'Purchase Invoice' => 'Einkaufsrechnung', 'Purchase Order' => 'Lieferantenauftrag', 'Purchase Orders' => 'Lieferantenaufträge', + 'Purchase Orders deleteable' => 'Lieferantenaufträge löschbar', 'Purchase Price' => 'Einkaufspreis', 'Purchase Prices' => 'Einkaufspreise', 'Purchase delivery order' => 'Lieferschein (Einkauf)', 'Purchase invoices' => 'Einkaufsrechnungen', + 'Purchase invoices changeable' => 'Änderbarkeit von Einkaufsrechnunen', 'Purchase net amount' => 'EK-Betrag', 'Purchase price' => 'EK-Preis', 'Purchase price total' => 'EK-Betrag', @@ -1585,16 +1608,19 @@ $self->{texts} = { 'Saldo neu' => 'Saldo neu', 'Saldo per' => 'Saldo per', 'Sale Prices' => 'Verkaufspreise', + 'Sales Delivery Orders deleteable' => 'Verkaufslieferscheine löschbar', 'Sales Invoice' => 'Rechnung', 'Sales Invoices' => 'Kundenrechnung', 'Sales Order' => 'Kundenauftrag', 'Sales Orders' => 'Aufträge', + 'Sales Orders deleteable' => 'Kundenaufträge löschbar', 'Sales Price information' => 'Verkaufspreisinformation', 'Sales Report' => 'Verkaufsbericht', 'Sales and purchase invoices with inventory transactions with taxkeys' => 'Einkaufs- und Verkaufsrechnungen mit Warenbestandsbuchungen mit Steuerschlüsseln', 'Sales delivery order' => 'Lieferschein (Verkauf)', 'Sales invoice number' => 'Ausgangsrechnungsnummer', 'Sales invoices' => 'Verkaufsrechnungen', + 'Sales invoices changeable' => 'Änderbarkeit von Verkaufsrechnungen', 'Sales margin' => 'Marge', 'Sales margin %' => 'Marge prozentual', 'Sales net amount' => 'VK-Betrag', @@ -1684,13 +1710,33 @@ $self->{texts} = { 'Shipto is in use and was flagged invalid.' => 'Lieferadresse ist noch in Verwendung, und wurde als ungültig markiert.', 'Shopartikel' => 'Shopartikel', 'Short' => 'Knapp', + 'Should ap transactions be and when should they be changeable or deleteable after posting?' => 'Sollen Kreditorenbuchungen nach der Buchung zu ändern oder zu löschen sein?', + 'Should ar transactions be and when should they be changeable or deleteable after posting?' => 'Sollen Debitorenbuchungen nach der Buchung zu ändern oder zu löschen sein?', + 'Should gl transactions be and when should they be changeable or deleteable after posting?' => 'Sollen Dialogbuchungen nach der Buchung zu ändern oder zu löschen sein?', + 'Should payments be and when should they be changeable after posting?' => 'Sollen Zahlungen nach dem Buchen änderbar sein, und wenn ja, wann?', + 'Should purchase invoices be and when should they be deleteable after posting?' => 'Sollen Einkaufsrechnungen nach der Buchung zu löschen sein?', + 'Should sales invoices be and when should they be changeable or deleteable after posting?' => 'Sollen Verkaufrechnung nach der Buchung zu ändern oder zu löschen sein?', + 'Should the "mark as paid" button showed in ap transactions?' => 'Soll der Knopf "als bezahlt markieren" bei Kreditorenbuchungen angezeigt werden?', + 'Should the "mark as paid" button showed in ar transactions?' => 'Soll der Knopf "als bezahlt markieren" bei Debitorenbuchungen angezeigt werden?', + 'Should the "mark as paid" button showed in purchase invoices?' => 'Soll der Knopf "als bezahlt markieren" bei Einkaufsrechnungen angezeigt werden?', + 'Should the "mark as paid" button showed on sales invoices?' => 'Soll der Knopf "als bezahlt markieren" bei Verkaufsrechnungen angezeigt werden?', 'Show' => 'Zeigen', + 'Show "mark as paid" in ap transactions' => '"als bezahlt markieren" bei Kreditorenbuchungen anzeigen', + 'Show "mark as paid" in ar transactions' => '"als bezahlt markieren" bei Debitorenbuchungen anzeigen', + 'Show "mark as paid" in purchase invoices' => '"als bezahlt markieren" bei Einkaufsrechnungen anzeigen', + 'Show "mark as paid" in sales invoices' => '"als bezahlt markieren" bei Verkaufsrechnungen anzeigen', + 'Show Bestbefore' => 'Mindesthaltbarkeit anzeigen', 'Show Filter' => 'Filter zeigen', 'Show Salesman' => 'Verkäufer anzeigen', 'Show TODO list' => 'Aufgabenliste anzeigen', 'Show by default' => 'Standardmäßig anzeigen', 'Show custom variable search inputs' => 'Suchoptionen für Benutzerdefinierte Variablen verstecken', + 'Show delete button in purchase delivery orders?' => 'Soll der "Löschen"-Knopf bei Einkaufslieferscheinen angezeigt werden?', + 'Show delete button in purchase orders?' => 'Soll der "Löschen"-Knopf bei Lieferantenaufträgen angezeigt werden?', + 'Show delete button in sales delivery orders?' => 'Soll der "Löschen"-Knopf bei Verkaufslieferscheinen angezeigt werden?', + 'Show delete button in sales orders?' => 'Soll der "Löschen"-Knopf bei Kundenaufträgen angezeigt werden?', 'Show details' => 'Detailsanzeige', + 'Show fields used for the best before date?' => 'Felder zur Eingabe des Mindesthaltbarkeitsdatums anzeigen?', 'Show follow ups...' => 'Zeige Wiedervorlagen...', 'Show help text' => 'Hilfetext anzeigen', 'Show items from invoices individually' => 'Artikel aus Rechnungen anzeigen', @@ -1998,6 +2044,7 @@ $self->{texts} = { 'Therefore there\'s no need to create the same article more than once if it is sold or bought in/from another tax zone.' => 'Deswegen muss man den gleichen Artikel nicht mehr mehrmals anlegen, wenn er in verschiedenen Steuerzonen gehandelt werden soll.', 'These units can be based on other units so that kivitendo can convert prices when the user switches from one unit to another.' => 'Einheiten können auf anderen Einheiten basieren, sodass kivitendo Preise automatisch umrechnen kann, wenn die Benutzer zwischen solchen Einheiten umschalten.', 'These wrong entries cannot be fixed automatically.' => 'Diese Einträge können nicht automatisch bereinigt werden.', + 'This can be done with the following query:' => 'Dies kann mit der folgenden Datenbankabfrage erreicht werden:', 'This corresponds to kivitendo\'s behavior prior to version 2.4.4.' => 'Dies entspricht kivitendos Verhalten vor Version 2.4.4.', 'This could have happened for two reasons:' => 'Dies kann aus zwei Gründen geschehen sein:', 'This customer number is already in use.' => 'Diese Kundennummer wird bereits verwendet.', @@ -2007,6 +2054,9 @@ $self->{texts} = { 'This list is capped at 15 items to keep it fast. If you need a full list, please use reports.' => 'Diese Liste ist auf 15 Zeilen begrenzt. Wenn Sie eine vollständige Liste benötigen, erstellen Sie bitte einen Bericht.', 'This means that the user has created an AP transaction and chosen a taxkey for sales taxes, or that he has created an AR transaction and chosen a taxkey for input taxes.' => 'Das bedeutet, dass ein Benutzer eine Kreditorenbuchung angelegt und in ihr einen Umsatzsteuer-Steuerschlüssel verwendet oder eine Debitorenbuchung mit Vorsteuer-Steuerschlüssel angelegt hat.', 'This module can help you identify and correct such entries by analyzing the general ledger and presenting you likely solutions but also allowing you to fix problems yourself.' => 'Dieses Modul kann Ihnen helfen, problematische Einträge im Hauptbuch zu identifizieren und teilweise zu beheben. Dabei werden je nach Problem mögliche Lösungen aufgezeigt, wobei Sie die entscheiden können, welche Probleme automatisch gelöst werden sollen.', + 'This option controls the inventory system.' => 'Dieser Parameter legt die Warenbuchungsmethode fest.', + 'This option controls the method used for profit determination.' => 'Dieser Parameter legt die Berechnungsmethode für die Gewinnermittlung fest.', + 'This option controls the posting and calculation behavior for the accounting method.' => 'Dieser Parameter steuert die Buchungs- und Berechnungsmethoden für die Versteuerungsart.', 'This transaction has to be split into several transactions manually.' => 'Diese Buchung muss manuell in mehrere Buchungen aufgeteilt werden.', 'This update will change the nature the onhand of goods is tracked.' => 'Dieses update ändert die Art und Weise wie Lagermengen gezält werden.', 'This upgrade script tries to map all existing parts in the database to the newly created Buchungsgruppen.' => 'Dieses Upgradescript versucht, bei allen bestehenden Artikeln neu erstellte Buchungsgruppen zuzuordnen.', @@ -2164,7 +2214,7 @@ $self->{texts} = { 'Weight unit' => 'Gewichtseinheit', 'What term you are looking for?' => 'Nach welchem Begriff wollen Sie suchen?', 'What type of item is this?' => 'Was ist dieser Artikel?', - 'Which is located at doc/Kivitendo-Dokumentation.pdf. Click here: ' => 'Diese befindet sich unter doc/Kivitendo-Dokumentation.pdf. Klicken Sie hier:', + 'Which is located at doc/kivitendo-Dokumentation.pdf. Click here: ' => 'Diese befindet sich unter doc/kivitendo-Dokumentation.pdf. Klicken Sie hier:', 'With Extension Of Time' => 'mit Dauerfristverlängerung', 'Workflow Delivery Order' => 'Workflow Lieferschein', 'Workflow purchase_order' => 'Workflow Lieferantenauftrag', @@ -2172,7 +2222,6 @@ $self->{texts} = { 'Workflow sales_order' => 'Workflow Auftrag', 'Workflow sales_quotation' => 'Workflow Angebot', 'Wrong Period' => 'Falscher Zeitraum', - 'Wrong date format!' => 'Falsches Datumsformat!', 'Wrong tax keys recorded' => 'Gespeicherte Steuerschlüssel sind falsch', 'Wrong taxes recorded' => 'Gespeicherte Steuern passen nicht zum Steuerschlüssel', 'YYYY' => 'JJJJ', @@ -2289,6 +2338,7 @@ $self->{texts} = { 'ea' => 'St.', 'emailed to' => 'gemailt an', 'empty' => 'leer', + 'every time' => 'immer', 'executed' => 'ausgeführt', 'failed' => 'fehlgeschlagen', 'female' => 'weiblich', @@ -2312,6 +2362,8 @@ $self->{texts} = { 'kivitendo has found one or more problems in the general ledger.' => 'kivitendo hat ein oder mehrere Probleme im Hauptbuch gefunden.', 'kivitendo is about to update the database [ #1 ].' => 'kivitendo wird gleich die Datenbank [ #1 ] aktualisieren.', 'kivitendo is now able to manage warehouses instead of just tracking the amount of goods in your system.' => 'kivitendo enthält jetzt auch echte Lagerverwaultung anstatt reiner Mengenzählung.', + 'kivitendo needs to update the authentication database before you can proceed.' => 'kivitendo muss die Authentifizierungsdatenbank aktualisieren, bevor Sie fortfahren können.', + 'kivitendo will then update the database automatically.' => 'kivitendo wird die Datenbank daraufhin automatisch aktualisieren.', 'lead deleted!' => 'Kundenquelle gelöscht', 'lead saved!' => 'Kundenquelle geichert', 'list' => 'auflisten', @@ -2344,6 +2396,7 @@ $self->{texts} = { 'not yet executed' => 'Noch nicht ausgeführt', 'number' => 'Nummer', 'oe.pl::search called with unknown type' => 'oe.pl::search mit unbekanntem Typ aufgerufen', + 'on the same day' => 'am selben Tag', 'one-time execution' => 'einmalige Ausführung', 'only OB Transactions' => 'nur EB-Buchungen', 'open' => 'Offen', diff --git a/locale/de_DE/all b/locale/de_DE/all index eb83e18e3..e07e39aca 100644 --- a/locale/de_DE/all +++ b/locale/de_DE/all @@ -48,13 +48,17 @@ $self->{texts} = { 'AP Transaction Storno (one letter abbreviation)' => 'S', 'AP Transaction with Storno (abbreviation)' => 'K(S)', 'AP Transactions' => 'Eingangsrechnungen', + 'AP transactions changeable' => 'Änderbarkeit von Kreditorenbuchungen', 'AP transactions with sales taxkeys and/or AR transactions with input taxkeys' => 'Kreditorenbuchungen mit Umsatzsteuer-Steuerschlüsseln und/oder Debitorenbuchungen mit Vorsteuer-Steuerschlüsseln', 'AR' => 'Verkauf', 'AR Aging' => 'Forderungen', 'AR Transaction' => 'Debitorenbuchung', 'AR Transaction (abbreviation)' => 'D', 'AR Transactions' => 'Debitorenbuchungen', + 'AR transactions changeable' => 'Änderbarkeit von Debitorenbuchungen', 'ASSETS' => 'AKTIVA', + 'ATTENTION! If you enabled this feature you can not simply turn it off again without taking care that best_before fields are emptied in the database.' => 'ACHTUNG! Wenn Sie diese Einstellung aktivieren, dann können Sie sie später nicht ohne Weiteres deaktivieren, ohne dafür zu sorgen, dass die Felder der Mindeshaltbarkeitsdaten in der Datenbank leer gemacht werden.', + 'ATTENTION! You can not simply change it from periodic to perpetual once you started posting.' => 'ACHTUNG! Es kann nicht ohne Weiteres im laufenden Betrieb von der Aufwandsmethode zur Bestandsmethode gewechselt werden.', 'Abort' => 'Abbrechen', 'Abrechnungsnummer' => 'Abrechnungsnummer', 'Abteilung' => 'Abteilung', @@ -183,6 +187,7 @@ $self->{texts} = { 'An upper-case character is required.' => 'Ein Großbuchstabe ist vorgeschrieben.', 'Annotations' => 'Hilfe', 'Another user with the login #1 does already exist.' => 'Es existiert bereits ein anderer Benutzer mit diesem Login.', + 'Any stock contents containing a best before date will be impossible to stock out otherwise.' => 'Sonst können Artikel, bei denen ein Mindesthaltbarkeitsdatum gesetzt ist, nicht mehr ausgelagert werden.', 'Ap aging on %s' => 'Offene Verbindlichkeiten zum %s', 'Application Error. No Format given' => 'Fehler in der Anwendung. Das Ausgabeformat fehlt.', 'Application Error. Wrong Format' => 'Fehler in der Anwendung. Falsches Format: ', @@ -388,6 +393,11 @@ $self->{texts} = { 'Check' => 'Scheck', 'Check Details' => 'Bitte Angaben überprüfen', 'Check for duplicates' => 'Dublettencheck', + 'Check on ap transaction' => 'Prüfen bei Kreditorenbuchung', + 'Check on ar transaction' => 'Prüfen bei Debitorenbuchung', + 'Check on gl transaction' => 'Prüfen bei Dialogbuchung', + 'Check on purchase invoice' => 'Prüfen bei Einkaufsrechnung', + 'Check on sales invoice' => 'Prüfen bei Verkaufsrechnung', 'Checks' => 'Schecks', 'Choose Customer' => 'Endkunde wählen:', 'Choose Outputformat' => 'Ausgabeformat auswählen...', @@ -397,6 +407,8 @@ $self->{texts} = { 'Cleared Balance' => 'abgeschlossen', 'Clearing Tax Received (No 71)' => 'Verrechnung des Erstattungsbetrages erwünscht (Zeile 71)', 'Click on login name to edit!' => 'Zum Bearbeiten den Benutzernamen anklicken!', + 'Client Configuration' => 'Mandantenkonfiguration', + 'Client Configuration saved!' => 'Mandantenkonfiguration gespeichert!', 'Close' => 'Übernehmen', 'Close Books up to' => 'Die Bücher abschließen bis zum', 'Close Dialog' => 'Schließen', @@ -516,6 +528,7 @@ $self->{texts} = { 'Customers' => 'Kunden', 'Customers and vendors' => 'Kunden und Lieferanten', 'Customized Report' => 'Vorgewählte Zeiträume', + 'DATEV check configuration' => 'Einstellungen für DATEV-Prüfung', 'DATEV - Export Assistent' => 'DATEV-Exportassistent', 'DATEV Angaben' => 'DATEV-Angaben', 'DATEV Export' => 'DATEV-Export', @@ -869,6 +882,7 @@ $self->{texts} = { 'Full access to all functions' => 'Vollzugriff auf alle Funktionen', 'Fwd' => 'Vorwärts', 'GL Transaction' => 'Dialogbuchung', + 'GL transactions changeable' => 'Änderbarkeit von Dialogbuchungen', 'Gegenkonto' => 'Gegenkonto', 'Gender' => 'Geschlecht', 'General Ledger' => 'Buchhaltung', @@ -1000,6 +1014,7 @@ $self->{texts} = { 'It is possible that even after such a correction there is something wrong with this transaction (e.g. taxes that don\'t match the selected taxkey). Therefore you should re-run the general ledger analysis.' => 'Auch nach einer Korrektur kann es mit dieser Buchung noch weitere Probleme geben (z.B. nicht zum Steuerschlüssel passende Steuern), weshalb ein erneutes Ausführen der Hauptbuchanalyse empfohlen wird.', 'It is possible to do this automatically for some Buchungsgruppen, but not for all.' => 'Es ist möglich, dies für einige, aber nicht für alle Buchungsgruppen automatisch zu erledigen.', 'It is possible to do this automatically for some units, but for others the user has to chose the new unit.' => 'Das ist für einige Einheiten automatisch möglich, aber bei anderen muss der Benutzer die neue Einheit auswählen.', + 'It is possible to make a quick DATEV export everytime you post a record to ensure things work nicely with their data requirements. This will result in a slight overhead though you can enable this for each type of record independantly.' => 'Es ist möglich, bei jeder Buchung einen schnellen DATEV-Export durchzuführen, um sicherzustellen, dass die Datensätze den DATEV-Anforderungen genügen. Da dies einen kleinen Overhead bedeutet, lässt sich die Einstellung für jeden Buchungstyp getrennt einstellen.', 'It may optionally be compressed with "gzip".' => 'Sie darf optional mit "gzip" komprimiert sein.', 'It will simply set the taxkey to 0 (meaning "no taxes") which is the correct value for such inventory transactions.' => 'Es wird einfach die Steuerschlüssel auf 0 setzen, was "keine Steuer" bedeutet und für solche Warenbestandsbuchungen der richtige Wert ist.', 'Item deleted!' => 'Artikel gelöscht!', @@ -1279,6 +1294,7 @@ $self->{texts} = { 'Order Number missing!' => 'Auftragsnummer fehlt!', 'Order deleted!' => 'Auftrag gelöscht!', 'Ordered' => 'Vom Kunde bestellt', + 'Orders / Delivery Orders deleteable' => 'Aufträge / Lieferscheine löschbar', 'Orientation' => 'Seitenformat', 'Orphaned' => 'Nie benutzt', 'Other users\' follow-ups' => 'Wiedervorlagen anderer Benutzer', @@ -1333,7 +1349,13 @@ $self->{texts} = { 'Payment terms (database ID)' => 'Zahlungsbedingungen (Datenbank-ID)', 'Payment terms (name)' => 'Zahlungsbedingungen (Name)', 'Payments' => 'Zahlungsausgänge', + 'Payments Changeable' => 'Änderbarkeit von Zahlungen', 'Per. Inv.' => 'Wied. Rech.', + 'Perform check when a gl transaction is posted?' => 'Prüfung durchführen, wenn eine Dialogbuchung gebucht wird?', + 'Perform check when a purchase invoice or a payment for a purchase invoice is posted?' => 'Prüfung durchführen, wenn eine Einkaufsrechnung oder ein Zahlungsausgang hierfür gebucht wird?', + 'Perform check when a sales invoice or a payment for a sales invoice is posted?' => 'Prüfung durchführen, wenn eine Verkaufsrechnung oder ein Zahlungseingang hierfür gebucht wird?', + 'Perform check when an ap transaction is posted?' => 'Prüfung durchführen, wenn eine Kreditorenbuchung gebucht wird?', + 'Perform check when an ar transaction is posted?' => 'Prüfung durchführen, wenn eine Debiotorenbuchung gebucht wird?', 'Period' => 'Zeitraum', 'Period:' => 'Zeitraum:', 'Periodic Invoices' => 'Wiederkehrende Rechnungen', @@ -1381,6 +1403,7 @@ $self->{texts} = { 'Post' => 'Buchen', 'Post Payment' => 'Zahlung buchen', 'Post payments' => 'Zahlungen buchen', + 'Posting Configuration' => 'Buchungskonfiguration', 'Postscript' => 'Postscript', 'Posustva_coa' => 'USTVA Kennz.', 'Preferences' => 'Einstellungen', @@ -1441,13 +1464,16 @@ $self->{texts} = { 'Projects' => 'Projekte', 'Projecttransactions' => 'Projektbuchungen', 'Prozentual/Absolut' => 'Prozentual/Absolut', + 'Purchase Delivery Orders deleteable' => 'Einkaufslieferscheine löschbar', 'Purchase Invoice' => 'Einkaufsrechnung', 'Purchase Order' => 'Lieferantenauftrag', 'Purchase Orders' => 'Einkaufsbestellungen', + 'Purchase Orders deleteable' => 'Lieferantenaufträge löschbar', 'Purchase Price' => 'Einkaufspreis', 'Purchase Prices' => 'Einkaufspreise', 'Purchase delivery order' => 'Lieferschein (Einkauf)', 'Purchase invoices' => 'Einkaufsrechnungen', + 'Purchase invoices changeable' => 'Änderbarkeit von Einkaufsrechnunen', 'Purchase net amount' => 'EK-Summe', 'Purchase price' => 'EK-Preis', 'Purchase price total' => 'EK-Summe', @@ -1541,16 +1567,19 @@ $self->{texts} = { 'Saldo neu' => 'Saldo neu', 'Saldo per' => 'Saldo per', 'Sale Prices' => 'Verkaufspreise', + 'Sales Delivery Orders deleteable' => 'Verkaufslieferscheine löschbar', 'Sales Invoice' => 'Rechnung', 'Sales Invoices' => 'Ausgangsrechnungen', 'Sales Order' => 'Kundenauftrag', 'Sales Orders' => 'Aufträge', + 'Sales Orders deleteable' => 'Kundenaufträge löschbar', 'Sales Price information' => '', 'Sales Report' => 'Verkaufsbericht', 'Sales and purchase invoices with inventory transactions with taxkeys' => 'Einkaufs- und Verkaufsrechnungen mit Warenbestandsbuchungen mit Steuerschlüsseln', 'Sales delivery order' => 'Lieferschein (Verkauf)', 'Sales invoice number' => 'Ausgangsrechnungsnummer', 'Sales invoices' => 'Verkaufsrechnungen', + 'Sales invoices changeable' => 'Änderbarkeit von Verkaufsrechnungen', 'Sales margin' => 'Marge', 'Sales margin %' => 'Marge prozentual', 'Sales net amount' => 'VK-Netto', @@ -1636,12 +1665,32 @@ $self->{texts} = { 'Shipto is in use and was flagged invalid.' => 'Lieferadresse ist noch in Verwendung, und wurde als ungültig markiert.', 'Shopartikel' => 'Shopartikel', 'Short' => 'Knapp', + 'Should ap transactions be and when should they be changeable or deleteable after posting?' => 'Sollen Kreditorenbuchungen nach der Buchung zu ändern oder zu löschen sein?', + 'Should ar transactions be and when should they be changeable or deleteable after posting?' => 'Sollen Debitorenbuchungen nach der Buchung zu ändern oder zu löschen sein?', + 'Should gl transactions be and when should they be changeable or deleteable after posting?' => 'Sollen Dialogbuchungen nach der Buchung zu ändern oder zu löschen sein?', + 'Should payments be and when should they be changeable after posting?' => 'Sollen Zahlungen nach dem Buchen änderbar sein, und wenn ja, wann?', + 'Should purchase invoices be and when should they be deleteable after posting?' => 'Sollen Einkaufsrechnungen nach der Buchung zu löschen sein?', + 'Should sales invoices be and when should they be changeable or deleteable after posting?' => 'Sollen Verkaufrechnung nach der Buchung zu ändern oder zu löschen sein?', + 'Should the "mark as paid" button showed in ap transactions?' => 'Soll der Knopf "als bezahlt markieren" bei Kreditorenbuchungen angezeigt werden?', + 'Should the "mark as paid" button showed in ar transactions?' => 'Soll der Knopf "als bezahlt markieren" bei Debitorenbuchungen angezeigt werden?', + 'Should the "mark as paid" button showed in purchase invoices?' => 'Soll der Knopf "als bezahlt markieren" bei Einkaufsrechnungen angezeigt werden?', + 'Should the "mark as paid" button showed on sales invoices?' => 'Soll der Knopf "als bezahlt markieren" bei Verkaufsrechnungen angezeigt werden?', 'Show' => 'Zeigen', + 'Show "mark as paid" in ap transactions' => '"als bezahlt markieren" bei Kreditorenbuchungen anzeigen', + 'Show "mark as paid" in ar transactions' => '"als bezahlt markieren" bei Debitorenbuchungen anzeigen', + 'Show "mark as paid" in purchase invoices' => '"als bezahlt markieren" bei Einkaufsrechnungen anzeigen', + 'Show "mark as paid" in sales invoices' => '"als bezahlt markieren" bei Verkaufsrechnungen anzeigen', + 'Show Bestbefore' => 'Mindesthaltbarkeit anzeigen', 'Show Salesman' => 'Verkäufer anzeigen', 'Show TODO list' => 'Meine Aufgaben', 'Show by default' => 'Standardmäßig anzeigen', 'Show custom variable search inputs' => 'Suche in erweiterten Datenfeldern', + 'Show delete button in purchase delivery orders?' => 'Soll der "Löschen"-Knopf bei Einkaufslieferscheinen angezeigt werden?', + 'Show delete button in purchase orders?' => 'Soll der "Löschen"-Knopf bei Lieferantenaufträgen angezeigt werden?', + 'Show delete button in sales delivery orders?' => 'Soll der "Löschen"-Knopf bei Verkaufslieferscheinen angezeigt werden?', + 'Show delete button in sales orders?' => 'Soll der "Löschen"-Knopf bei Kundenaufträgen angezeigt werden?', 'Show details' => 'Detailsanzeige', + 'Show fields used for the best before date?' => 'Felder zur Eingabe des Mindesthaltbarkeitsdatums anzeigen?', 'Show follow ups...' => 'Zeige Wiedervorlagen...', 'Show help text' => 'Hilfetext anzeigen', 'Show old dunnings' => 'Alte Mahnungen anzeigen', @@ -1925,6 +1974,7 @@ $self->{texts} = { 'Therefore there\'s no need to create the same article more than once if it is sold or bought in/from another tax zone.' => 'Deswegen muss man den gleichen Artikel nicht mehr mehrmals anlegen, wenn er in verschiedenen Steuerzonen gehandelt werden soll.', 'These units can be based on other units so that Lx-Office can convert prices when the user switches from one unit to another.' => 'Diese Einheiten können auf anderen Einheiten basieren, sodass Lx-Office Preise umrechnen kann, wenn der Benutzer von einer Einheit zu einer anderen Wechselt.', 'These wrong entries cannot be fixed automatically.' => 'Diese Einträge können nicht automatisch bereinigt werden.', + 'This can be done with the following query:' => 'Dies kann mit der folgenden Datenbankabfrage erreicht werden:', 'This corresponds to Lx-Office\'s behavior prior to version 2.4.4.' => 'Dieses entspricht dem Verhalten von Lx-Office vor Version 2.4.4.', 'This could have happened for two reasons:' => 'Dies kann aus zwei Gründen geschehen sein:', 'This customer number is already in use.' => 'Diese Kundennummer wird bereits verwendet.', @@ -1934,6 +1984,9 @@ $self->{texts} = { 'This list is capped at 15 items to keep it fast. If you need a full list, please use reports.' => 'Diese Liste ist auf 15 Zeilen begrenzt. Wenn Sie eine vollständige Liste benötigen, erstellen Sie bitte einen Bericht.', 'This means that the user has created an AP transaction and chosen a taxkey for sales taxes, or that he has created an AR transaction and chosen a taxkey for input taxes.' => 'Das bedeutet, dass ein Benutzer eine Kreditorenbuchung angelegt und in ihr einen Umsatzsteuer-Steuerschlüssel verwendet oder eine Debitorenbuchung mit Vorsteuer-Steuerschlüssel angelegt hat.', 'This module can help you identify and correct such entries by analyzing the general ledger and presenting you likely solutions but also allowing you to fix problems yourself.' => 'Dieses Modul kann Ihnen helfen, problematische Einträge im Hauptbuch zu identifizieren und teilweise zu beheben. Dabei werden je nach Problem mögliche Lösungen aufgezeigt, wobei Sie die entscheiden können, welche Probleme automatisch gelöst werden sollen.', + 'This option controls the inventory system.' => 'Dieser Parameter legt die Warenbuchungsmethode fest.', + 'This option controls the method used for profit determination.' => 'Dieser Parameter legt die Berechnungsmethode für die Gewinnermittlung fest.', + 'This option controls the posting and calculation behavior for the accounting method.' => 'Dieser Parameter steuert die Buchungs- und Berechnungsmethoden für die Versteuerungsart.', 'This transaction has to be split into several transactions manually.' => 'Diese Buchung muss manuell in mehrere Buchungen aufgeteilt werden.', 'This update will change the nature the onhand of goods is tracked.' => 'Dieses update ändert die Art und Weise wie Lagermengen gezält werden.', 'This upgrade script tries to map all existing parts in the database to the newly created Buchungsgruppen.' => 'Dieses Upgradescript versucht, bei allen bestehenden Artikeln neu erstellte Buchungsgruppen zuzuordnen.', @@ -2209,6 +2262,7 @@ $self->{texts} = { 'eMail?' => 'eMail?', 'ea' => 'St.', 'emailed to' => 'gemailt an', + 'every time' => 'immer', 'executed' => 'ausgeführt', 'female' => 'weiblich', 'follow_up_list' => 'wiedervorlageliste', @@ -2250,6 +2304,7 @@ $self->{texts} = { 'not yet executed' => 'Noch nicht ausgeführt', 'number' => 'Nummer', 'oe.pl::search called with unknown type' => 'oe.pl::search mit unbekanntem Typ aufgerufen', + 'on the same day' => 'am selben Tag', 'only OB Transactions' => 'nur EB-Buchungen', 'open' => 'Offen', 'order' => 'Reihenfolge', diff --git a/locale/en/all b/locale/en/all index ac7ffddd5..89a4ddf1c 100644 --- a/locale/en/all +++ b/locale/en/all @@ -48,13 +48,17 @@ $self->{texts} = { 'AP Transaction Storno (one letter abbreviation)' => '', 'AP Transaction with Storno (abbreviation)' => '', 'AP Transactions' => 'Purchase Transactions', + 'AP transactions changeable' => '', 'AP transactions with sales taxkeys and/or AR transactions with input taxkeys' => '', 'AR' => 'Sales', 'AR Aging' => 'Debtor Aging', 'AR Transaction' => 'Sales Transaction', 'AR Transaction (abbreviation)' => '', 'AR Transactions' => 'Sales Transactions', + 'AR transactions changeable' => '', 'ASSETS' => '', + 'ATTENTION! If you enabled this feature you can not simply turn it off again without taking care that best_before fields are emptied in the database.' => '', + 'ATTENTION! You can not simply change it from periodic to perpetual once you started posting.' => '', 'Abort' => '', 'Abrechnungsnummer' => '', 'Abteilung' => '', @@ -183,6 +187,7 @@ $self->{texts} = { 'An upper-case character is required.' => '', 'Annotations' => '', 'Another user with the login #1 does already exist.' => '', + 'Any stock contents containing a best before date will be impossible to stock out otherwise.' => '', 'Ap aging on %s' => '', 'Application Error. No Format given' => '', 'Application Error. Wrong Format' => '', @@ -389,6 +394,11 @@ $self->{texts} = { 'Check' => 'Cheque', 'Check Details' => '', 'Check for duplicates' => '', + 'Check on ap transaction' => '', + 'Check on ar transaction' => '', + 'Check on gl transaction' => '', + 'Check on purchase invoice' => '', + 'Check on sales invoice' => '', 'Checks' => '', 'Choose Customer' => '', 'Choose Outputformat' => '', @@ -398,6 +408,8 @@ $self->{texts} = { 'Cleared Balance' => '', 'Clearing Tax Received (No 71)' => '', 'Click on login name to edit!' => '', + 'Client Configuration' => '', + 'Client Configuration saved!' => '', 'Close' => '', 'Close Books up to' => '', 'Close Dialog' => '', @@ -527,6 +539,7 @@ $self->{texts} = { 'DATEV - Export Assistent' => '', 'DATEV Angaben' => '', 'DATEV Export' => '', + 'DATEV check configuration' => '', 'DATEV check returned errors:' => '', 'DATEX - Export Assistent' => '', 'DELETED' => '', @@ -884,6 +897,7 @@ $self->{texts} = { 'Full access to all functions' => '', 'Fwd' => 'Forward', 'GL Transaction' => '', + 'GL transactions changeable' => '', 'Gegenkonto' => '', 'Gender' => '', 'General Ledger' => '', @@ -1016,6 +1030,7 @@ $self->{texts} = { 'It is possible that even after such a correction there is something wrong with this transaction (e.g. taxes that don\'t match the selected taxkey). Therefore you should re-run the general ledger analysis.' => '', 'It is possible to do this automatically for some Buchungsgruppen, but not for all.' => '', 'It is possible to do this automatically for some units, but for others the user has to chose the new unit.' => '', + 'It is possible to make a quick DATEV export everytime you post a record to ensure things work nicely with their data requirements. This will result in a slight overhead though you can enable this for each type of record independantly.' => '', 'It may optionally be compressed with "gzip".' => '', 'It will simply set the taxkey to 0 (meaning "no taxes") which is the correct value for such inventory transactions.' => '', 'Item deleted!' => '', @@ -1035,8 +1050,8 @@ $self->{texts} = { 'KNE-Export erfolgreich!' => '', 'KNr. beim Kunden' => '', 'Keine Suchergebnisse gefunden!' => '', - 'Kivitendo needs to update the authentication database before you can proceed.' => '', - 'Kivitendo will then update the database automatically.' => '', + 'kivitendo needs to update the authentication database before you can proceed.' => '', + 'kivitendo will then update the database automatically.' => '', 'Konten' => '', 'L' => '', 'LIABILITIES' => '', @@ -1295,6 +1310,7 @@ $self->{texts} = { 'Order Number missing!' => '', 'Order deleted!' => '', 'Ordered' => '', + 'Orders / Delivery Orders deleteable' => '', 'Orientation' => '', 'Orphaned' => '', 'Other users\' follow-ups' => '', @@ -1349,7 +1365,13 @@ $self->{texts} = { 'Payment terms (database ID)' => '', 'Payment terms (name)' => '', 'Payments' => '', + 'Payments Changeable' => '', 'Per. Inv.' => '', + 'Perform check when a gl transaction is posted?' => '', + 'Perform check when a purchase invoice or a payment for a purchase invoice is posted?' => '', + 'Perform check when a sales invoice or a payment for a sales invoice is posted?' => '', + 'Perform check when an ap transaction is posted?' => '', + 'Perform check when an ar transaction is posted?' => '', 'Period' => '', 'Period:' => '', 'Periodic Invoices' => '', @@ -1397,6 +1419,7 @@ $self->{texts} = { 'Post' => '', 'Post Payment' => '', 'Post payments' => '', + 'Posting Configuration' => '', 'Postscript' => '', 'Posustva_coa' => '', 'Preferences' => '', @@ -1458,13 +1481,16 @@ $self->{texts} = { 'Projects' => '', 'Projecttransactions' => '', 'Prozentual/Absolut' => '', + 'Purchase Delivery Orders deleteable' => '', 'Purchase Invoice' => '', 'Purchase Order' => '', 'Purchase Orders' => '', + 'Purchase Orders deleteable' => '', 'Purchase Price' => '', 'Purchase Prices' => '', 'Purchase delivery order' => '', 'Purchase invoices' => '', + 'Purchase invoices changeable' => '', 'Purchase net amount' => '', 'Purchase price' => '', 'Purchase price total' => '', @@ -1560,16 +1586,19 @@ $self->{texts} = { 'Saldo neu' => '', 'Saldo per' => '', 'Sale Prices' => '', + 'Sales Delivery Orders deleteable' => '', 'Sales Invoice' => '', 'Sales Invoices' => '', 'Sales Order' => '', 'Sales Orders' => '', + 'Sales Orders deleteable' => '', 'Sales Price information' => '', 'Sales Report' => '', 'Sales and purchase invoices with inventory transactions with taxkeys' => '', 'Sales delivery order' => '', 'Sales invoice number' => '', 'Sales invoices' => '', + 'Sales invoices changeable' => '', 'Sales margin' => '', 'Sales margin %' => '', 'Sales net amount' => '', @@ -1658,13 +1687,33 @@ $self->{texts} = { 'Shipto is in use and was flagged invalid.' => '', 'Shopartikel' => '', 'Short' => '', + 'Should ap transactions be and when should they be changeable or deleteable after posting?' => '', + 'Should ar transactions be and when should they be changeable or deleteable after posting?' => '', + 'Should gl transactions be and when should they be changeable or deleteable after posting?' => '', + 'Should payments be and when should they be changeable after posting?' => '', + 'Should purchase invoices be and when should they be deleteable after posting?' => '', + 'Should sales invoices be and when should they be changeable or deleteable after posting?' => '', + 'Should the "mark as paid" button showed in ap transactions?' => '', + 'Should the "mark as paid" button showed in ar transactions?' => '', + 'Should the "mark as paid" button showed in purchase invoices?' => '', + 'Should the "mark as paid" button showed on sales invoices?' => '', 'Show' => '', + 'Show "mark as paid" in ap transactions' => '', + 'Show "mark as paid" in ar transactions' => '', + 'Show "mark as paid" in purchase invoices' => '', + 'Show "mark as paid" in sales invoices' => '', + 'Show Bestbefore' => '', 'Show Filter' => '', 'Show Salesman' => '', 'Show TODO list' => '', 'Show by default' => '', 'Show custom variable search inputs' => '', + 'Show delete button in purchase delivery orders?' => '', + 'Show delete button in purchase orders?' => '', + 'Show delete button in sales delivery orders?' => '', + 'Show delete button in sales orders?' => '', 'Show details' => '', + 'Show fields used for the best before date?' => '', 'Show follow ups...' => '', 'Show help text' => '', 'Show items from invoices individually' => '', @@ -1949,6 +1998,7 @@ $self->{texts} = { 'Therefore there\'s no need to create the same article more than once if it is sold or bought in/from another tax zone.' => '', 'These units can be based on other units so that kivitendo can convert prices when the user switches from one unit to another.' => '', 'These wrong entries cannot be fixed automatically.' => '', + 'This can be done with the following query:' => '', 'This corresponds to kivitendo\'s behavior prior to version 2.4.4.' => '', 'This could have happened for two reasons:' => '', 'This customer number is already in use.' => '', @@ -1958,6 +2008,9 @@ $self->{texts} = { 'This list is capped at 15 items to keep it fast. If you need a full list, please use reports.' => '', 'This means that the user has created an AP transaction and chosen a taxkey for sales taxes, or that he has created an AR transaction and chosen a taxkey for input taxes.' => '', 'This module can help you identify and correct such entries by analyzing the general ledger and presenting you likely solutions but also allowing you to fix problems yourself.' => '', + 'This option controls the inventory system.' => '', + 'This option controls the method used for profit determination.' => '', + 'This option controls the posting and calculation behavior for the accounting method.' => '', 'This transaction has to be split into several transactions manually.' => '', 'This update will change the nature the onhand of goods is tracked.' => '', 'This upgrade script tries to map all existing parts in the database to the newly created Buchungsgruppen.' => '', @@ -2112,7 +2165,7 @@ $self->{texts} = { 'Weight unit' => '', 'What term you are looking for?' => '', 'What type of item is this?' => '', - 'Which is located at doc/Kivitendo-Dokumentation.pdf. Click here: ' => '', + 'Which is located at doc/kivitendo-Dokumentation.pdf. Click here: ' => '', 'With Extension Of Time' => '', 'Workflow Delivery Order' => '', 'Workflow purchase_order' => '', @@ -2238,6 +2291,7 @@ $self->{texts} = { 'ea' => '', 'emailed to' => '', 'empty' => '', + 'every time' => '', 'executed' => '', 'female' => '', 'follow_up_list' => '', @@ -2273,6 +2327,7 @@ $self->{texts} = { 'missing' => '', 'month' => '', 'monthly' => '', + 'never' => '', 'new Window' => '', 'next' => '', 'no' => '', @@ -2288,6 +2343,7 @@ $self->{texts} = { 'not yet executed' => '', 'number' => '', 'oe.pl::search called with unknown type' => '', + 'on the same day' => '', 'only OB Transactions' => '', 'open' => '', 'order' => '', diff --git a/menu.ini b/menu.ini index ca7c972f7..cb0700309 100644 --- a/menu.ini +++ b/menu.ini @@ -824,6 +824,11 @@ action=audit_control module=am.pl action=show_history_search +[System--Client Configuration] +ACCESS=admin +module=controller.pl +action=ClientConfig/edit + [System--Employees] ACCESS=admin module=controller.pl diff --git a/scripts/boot/system-v/kivitendo-task-server b/scripts/boot/system-v/kivitendo-task-server index cab569610..c275676d2 100755 --- a/scripts/boot/system-v/kivitendo-task-server +++ b/scripts/boot/system-v/kivitendo-task-server @@ -7,14 +7,14 @@ # Default-Start: 2 3 4 5 # Default-Stop: 0 1 6 # X-Interactive: true -# Short-Description: Start/stop the Kivitendo task server +# Short-Description: Start/stop the kivitendo task server ### END INIT INFO set -e -# Change this to point to the Kivitendo "task_server.pl" location. +# Change this to point to the kivitendo "task_server.pl" location. DAEMON="/opt/kivitendo/scripts/task_server.pl" -TOPIC="Kivitendo task server" +TOPIC="kivitendo task server" if [ ! -x $DAEMON ] ; then echo "$TOPIC executable not found" diff --git a/scripts/boot/upstart/kivitendo-task-server.conf b/scripts/boot/upstart/kivitendo-task-server.conf index b3666dba0..4d4ac904a 100644 --- a/scripts/boot/upstart/kivitendo-task-server.conf +++ b/scripts/boot/upstart/kivitendo-task-server.conf @@ -1,6 +1,6 @@ -# kivitendo-task-server - Task server for Kivitendo +# kivitendo-task-server - Task server for kivitendo -description "Kivitendo task server" +description "kivitendo task server" start on runlevel [2345] stop on runlevel [!2345] diff --git a/scripts/locales.pl b/scripts/locales.pl index f52641630..28b56323c 100755 --- a/scripts/locales.pl +++ b/scripts/locales.pl @@ -9,15 +9,16 @@ use utf8; use strict; +use Carp; use Data::Dumper; use English; +use File::Slurp qw(slurp); use FileHandle; use Getopt::Long; +use IO::Dir; use List::Util qw(first); use POSIX; use Pod::Usage; -use Carp; -use File::Slurp qw(slurp); $OUTPUT_AUTOFLUSH = 1; @@ -36,6 +37,9 @@ my $dbupdir = "$basedir/sql/Pg-upgrade"; my $dbupdir2 = "$basedir/sql/Pg-upgrade2"; my $menufile = "menu.ini"; my $submitsearch = qr/type\s*=\s*[\"\']?submit/i; +our $self = {}; +our $missing = {}; +our @lost = (); my (%referenced_html_files, %locale, %htmllocale, %alllocales, %cached, %submit); my ($ALL_HEADER, $MISSING_HEADER, $LOST_HEADER); @@ -43,30 +47,33 @@ my ($ALL_HEADER, $MISSING_HEADER, $LOST_HEADER); init(); sub find_files { - my ($dir_name, $files) = @_; + my ($top_dir_name) = @_; - $files ||= []; + my (@files, $finder); - my @dirs_to_check; + $finder = sub { + my ($dir_name) = @_; - opendir my $dir, $dir_name or die "$! $dir_name"; + tie my %dir_h, 'IO::Dir', $dir_name; - foreach my $name (readdir $dir) { - next if $name eq '.' || $name eq '..'; + push @files, grep { -f } map { "${dir_name}/${_}" } keys %dir_h; + my @sub_dirs = grep { -d } map { "${dir_name}/${_}" } grep { ! m/^\.\.?$/ } keys %dir_h; - my $full_name = "${dir_name}/${name}"; - if (-d $full_name) { - push @dirs_to_check, $full_name; - } else { - push @{ $files }, $full_name; - } - } + $finder->($_) for @sub_dirs; + }; - closedir $dir; + $finder->($top_dir_name); - map { find_files($_, $files) } @dirs_to_check; + return @files; +} - return @{ $files }; +sub merge_texts { +# overwrite existing entries with the ones from 'missing' + $self->{texts}->{$_} = $missing->{$_} for grep { $missing->{$_} } keys %alllocales; + + # try to set missing entries from lost ones + my %lost_by_text = map { ($_->{text} => $_->{translation}) } @lost; + $self->{texts}->{$_} = $lost_by_text{$_} for grep { !$self->{texts}{$_} } keys %alllocales; } my @bindir_files = find_files($bindir); @@ -76,32 +83,24 @@ my @customfiles = grep /_custom/, @bindir_files; push @progfiles, map { m:^(.+)/([^/]+)$:; [ $2, $1 ] } grep { /\.pm$/ } map { find_files($_) } @progdirs; # put customized files into @customfiles -my @menufiles; +my (@menufiles, %dir_h); if ($opt_n) { @customfiles = (); @menufiles = ($menufile); } else { - opendir DIR, "$basedir" or die "$!"; - @menufiles = grep { /.*?_$menufile$/ } readdir DIR; - closedir DIR; - unshift @menufiles, $menufile; + tie %dir_h, 'IO::Dir', $basedir; + @menufiles = map { "$basedir/$_" } grep { /.*?_$menufile$/ } keys %dir_h; + unshift @menufiles, "$basedir/$menufile"; } -opendir DIR, $dbupdir or die "$!"; -my @dbplfiles = grep { /\.pl$/ } readdir DIR; -closedir DIR; +tie %dir_h, 'IO::Dir', $dbupdir; +my @dbplfiles = grep { /\.pl$/ } keys %dir_h; -opendir DIR, $dbupdir2 or die "$!"; -my @dbplfiles2 = grep { /\.pl$/ } readdir DIR; -closedir DIR; +tie %dir_h, 'IO::Dir', $dbupdir2; +my @dbplfiles2 = grep { /\.pl$/ } keys %dir_h; # slurp the translations in -our $self = {}; -our $missing = {}; -our @missing = (); -our @lost = (); - if (-f "$locales_dir/all") { require "$locales_dir/all"; } @@ -119,9 +118,13 @@ chomp $charset; my %old_texts = %{ $self->{texts} || {} }; -map({ handle_file(@{ $_ }); } @progfiles); -map({ handle_file($_, $dbupdir); } @dbplfiles); -map({ handle_file($_, $dbupdir2); } @dbplfiles2); +handle_file(@{ $_ }) for @progfiles; +handle_file($_, $dbupdir) for @dbplfiles; +handle_file($_, $dbupdir2) for @dbplfiles2; +scanmenu($_) for @menufiles; + +# merge entries to translate with entries from files 'missing' and 'lost' +merge_texts(); # generate all generate_file( @@ -131,15 +134,24 @@ generate_file( data_sub => sub { _print_line($_, $self->{texts}{$_}, @_) for sort keys %alllocales }, ); + foreach my $text (keys %$missing) { + if ($locale{$text} || $htmllocale{$text}) { + unless ($self->{texts}{$text}) { + $self->{texts}{$text} = $missing->{$text}; + } + } + } + + # calc and generate missing -push @missing, grep { !$self->{texts}{$_} } sort keys %alllocales; +my @new_missing = grep { !$self->{texts}{$_} } sort keys %alllocales; -if (@missing) { +if (@new_missing) { generate_file( file => "$locales_dir/missing", header => $MISSING_HEADER, data_name => '$missing', - data_sub => sub { _print_line($_, '', @_) for @missing }, + data_sub => sub { _print_line($_, '', @_) for @new_missing }, ); } @@ -168,7 +180,7 @@ chomp $trlanguage; search_unused_htmlfiles() if $opt_c; my $count = scalar keys %alllocales; -my $notext = scalar @missing; +my $notext = scalar @new_missing; my $per = sprintf("%.1f", ($count - $notext) / $count * 100); print "\n$trlanguage - ${per}%"; print " - $notext/$count missing" if $notext; @@ -255,14 +267,6 @@ sub handle_file { } $file =~ s/\.pl//; - - foreach my $text (keys %$missing) { - if ($locale{$text} || $htmllocale{$text}) { - unless ($self->{texts}{$text}) { - $self->{texts}{$text} = $missing->{$text}; - } - } - } } sub extract_text_between_parenthesis { @@ -430,14 +434,15 @@ sub scanfile { } - map { $alllocales{$_} = 1 } keys %{$cached{$file}{all}}; - map { $locale{$_} = 1 } keys %{$cached{$file}{locale}}; - map { $submit{$_} = 1 } keys %{$cached{$file}{submit}}; - map { &scanfile($_, 0, $scanned_files) } keys %{$cached{$file}{scan}}; - map { &scanfile($_, 1, $scanned_files) } keys %{$cached{$file}{scannosubs}}; - map { &scanhtmlfile($_) } keys %{$cached{$file}{scanh}}; + $alllocales{$_} = 1 for keys %{$cached{$file}{all}}; + $locale{$_} = 1 for keys %{$cached{$file}{locale}}; + $submit{$_} = 1 for keys %{$cached{$file}{submit}}; + + scanfile($_, 0, $scanned_files) for keys %{$cached{$file}{scan}}; + scanfile($_, 1, $scanned_files) for keys %{$cached{$file}{scannosubs}}; + scanhtmlfile($_) for keys %{$cached{$file}{scanh}}; - @referenced_html_files{keys %{$cached{$file}{scanh}}} = (1) x scalar keys %{$cached{$file}{scanh}}; + $referenced_html_files{$_} = 1 for keys %{$cached{$file}{scanh}}; } sub scanmenu { @@ -555,13 +560,13 @@ sub scanhtmlfile { } # copy back into global arrays - map { $alllocales{$_} = 1 } keys %{$cached{$file}{all}}; - map { $locale{$_} = 1 } keys %{$cached{$file}{html}}; - map { $submit{$_} = 1 } keys %{$cached{$file}{submit}}; + $alllocales{$_} = 1 for keys %{$cached{$file}{all}}; + $locale{$_} = 1 for keys %{$cached{$file}{html}}; + $submit{$_} = 1 for keys %{$cached{$file}{submit}}; - map { scanhtmlfile($_) } keys %{$cached{$file}{scanh}}; + scanhtmlfile($_) for keys %{$cached{$file}{scanh}}; - @referenced_html_files{keys %{$cached{$file}{scanh}}} = (1) x scalar keys %{$cached{$file}{scanh}}; + $referenced_html_files{$_} = 1 for keys %{$cached{$file}{scanh}}; } sub search_unused_htmlfiles { diff --git a/sql/Pg-upgrade2/defaults_datev_check.pl b/sql/Pg-upgrade2/defaults_datev_check.pl new file mode 100644 index 000000000..50772810b --- /dev/null +++ b/sql/Pg-upgrade2/defaults_datev_check.pl @@ -0,0 +1,54 @@ +# @tag: defaults_datev_check +# @description: Einstellung für DATEV-Überprüfungen (datev_check) vom Config-File in die DB verlagern. +# @depends: release_2_7_0 +# @charset: utf-8 + +use utf8; +use strict; + +die("This script cannot be run from the command line.") unless ($main::form); + +sub mydberror { + my ($msg) = @_; + die($dbup_locale->text("Database update error:") . + "
    $msg
    " . $DBI::errstr); +} + +sub do_query { + my ($query, $may_fail) = @_; + + if (!$dbh->do($query)) { + mydberror($query) unless ($may_fail); + $dbh->rollback(); + $dbh->begin_work(); + } +} + +sub do_update { + + # this query will fail if column already exist (new database) + do_query(qq|ALTER TABLE defaults ADD COLUMN datev_check_on_sales_invoice boolean DEFAULT true|, 1); + do_query(qq|ALTER TABLE defaults ADD COLUMN datev_check_on_purchase_invoice boolean DEFAULT true|, 1); + do_query(qq|ALTER TABLE defaults ADD COLUMN datev_check_on_ar_transaction boolean DEFAULT true|, 1); + do_query(qq|ALTER TABLE defaults ADD COLUMN datev_check_on_ap_transaction boolean DEFAULT true|, 1); + do_query(qq|ALTER TABLE defaults ADD COLUMN datev_check_on_gl_transaction boolean DEFAULT true|, 1); + + # check current configuration and set default variables accordingly, so that + # kivitendo's behaviour isn't changed by this update + # if checks are not set in config set it to true + foreach my $check (qw(check_on_sales_invoice check_on_purchase_invoice check_on_ar_transaction check_on_ap_transaction check_on_gl_transaction)) { + my $check_set = 1; + if (!$::lx_office_conf{datev_check}->{$check}) { + $check_set = 0; + } + + my $update_column = "UPDATE defaults SET datev_$check = '$check_set';"; + do_query($update_column); + } + + + return 1; +} + +return do_update(); + diff --git a/sql/Pg-upgrade2/defaults_posting_config.pl b/sql/Pg-upgrade2/defaults_posting_config.pl new file mode 100644 index 000000000..dd033d43c --- /dev/null +++ b/sql/Pg-upgrade2/defaults_posting_config.pl @@ -0,0 +1,49 @@ +# @tag: defaults_posting_config +# @description: Einstellung, ob und wann Zahlungen änderbar sind, vom Config-File in die DB verlagern. +# @depends: release_2_7_0 +# @charset: utf-8 + +use utf8; +use strict; + +die("This script cannot be run from the command line.") unless ($main::form); + +sub mydberror { + my ($msg) = @_; + die($dbup_locale->text("Database update error:") . + "
    $msg
    " . $DBI::errstr); +} + +sub do_query { + my ($query, $may_fail) = @_; + + if (!$dbh->do($query)) { + mydberror($query) unless ($may_fail); + $dbh->rollback(); + $dbh->begin_work(); + } +} + +sub do_update { + + # this query will fail if column already exist (new database) + do_query(qq|ALTER TABLE defaults ADD COLUMN payments_changeable integer NOT NULL DEFAULT 0|, 1); + + # check current configuration and set default variables accordingly, so that + # Lx-Office behaviour isn't changed by this update + # if payments_changeable is not set in config set it to 0 + my $payments_changeable = 0; + if ($::lx_office_conf{features}->{payments_changeable} == 1 ) { + $payments_changeable = 1; + } elsif ($::lx_office_conf{features}->{payments_changeable} == 2 ) { + $payments_changeable = 2; + } + + my $update_column = "UPDATE defaults SET payments_changeable = '$payments_changeable';"; + do_query($update_column); + + return 1; +} + +return do_update(); + diff --git a/sql/Pg-upgrade2/defaults_posting_records_config.sql b/sql/Pg-upgrade2/defaults_posting_records_config.sql new file mode 100644 index 000000000..d6ef50108 --- /dev/null +++ b/sql/Pg-upgrade2/defaults_posting_records_config.sql @@ -0,0 +1,10 @@ +-- @tag: defaults_posting_records_config +-- @description: Einstellung, ob und wann Belegbuchungen änderbar/löschbar sind. +-- @depends: release_2_7_0 +-- @charset: utf-8 + +ALTER TABLE defaults ADD COLUMN is_changeable integer NOT NULL DEFAULT 2; +ALTER TABLE defaults ADD COLUMN ir_changeable integer NOT NULL DEFAULT 2; +ALTER TABLE defaults ADD COLUMN ar_changeable integer NOT NULL DEFAULT 2; +ALTER TABLE defaults ADD COLUMN ap_changeable integer NOT NULL DEFAULT 2; +ALTER TABLE defaults ADD COLUMN gl_changeable integer NOT NULL DEFAULT 2; diff --git a/sql/Pg-upgrade2/defaults_show_bestbefore.pl b/sql/Pg-upgrade2/defaults_show_bestbefore.pl new file mode 100644 index 000000000..36b1882bc --- /dev/null +++ b/sql/Pg-upgrade2/defaults_show_bestbefore.pl @@ -0,0 +1,47 @@ +# @tag: defaults_show_bestbefore +# @description: Einstellung, ob Mindesthaltbarkeitsdatum angezeigt wird, vom Config-File in die DB verlagern. +# @depends: release_2_7_0 +# @charset: utf-8 + +use utf8; +use strict; + +die("This script cannot be run from the command line.") unless ($main::form); + +sub mydberror { + my ($msg) = @_; + die($dbup_locale->text("Database update error:") . + "
    $msg
    " . $DBI::errstr); +} + +sub do_query { + my ($query, $may_fail) = @_; + + if (!$dbh->do($query)) { + mydberror($query) unless ($may_fail); + $dbh->rollback(); + $dbh->begin_work(); + } +} + +sub do_update { + + # this query will fail if column already exist (new database) + do_query(qq|ALTER TABLE defaults ADD COLUMN show_bestbefore boolean DEFAULT false|, 1); + + # check current configuration and set default variables accordingly, so that + # Lx-Office behaviour isn't changed by this update + # if show_best_before is not set in config set it to 0 + my $show_bestbefore = 0; + if ($::lx_office_conf{features}->{show_best_before}) { + $show_bestbefore = 1; + } + + my $update_column = "UPDATE defaults SET show_bestbefore = '$show_bestbefore';"; + do_query($update_column); + + return 1; +} + +return do_update(); + diff --git a/sql/Pg-upgrade2/defaults_show_delete_on_orders.sql b/sql/Pg-upgrade2/defaults_show_delete_on_orders.sql new file mode 100644 index 000000000..6f876eb87 --- /dev/null +++ b/sql/Pg-upgrade2/defaults_show_delete_on_orders.sql @@ -0,0 +1,9 @@ +-- @tag: defaults_show_delete_on_orders +-- @description: Einstellung, ob der "Löschen"-Knopf bei Aufträgen und Lieferscheinen angezeigt wird. +-- @depends: release_2_7_0 +-- @charset: utf-8 + +ALTER TABLE defaults ADD COLUMN sales_order_show_delete boolean DEFAULT TRUE; +ALTER TABLE defaults ADD COLUMN purchase_order_show_delete boolean DEFAULT TRUE; +ALTER TABLE defaults ADD COLUMN sales_delivery_order_show_delete boolean DEFAULT TRUE; +ALTER TABLE defaults ADD COLUMN purchase_delivery_order_show_delete boolean DEFAULT TRUE; diff --git a/sql/Pg-upgrade2/defaults_show_mark_as_paid_config.sql b/sql/Pg-upgrade2/defaults_show_mark_as_paid_config.sql new file mode 100644 index 000000000..8635763f5 --- /dev/null +++ b/sql/Pg-upgrade2/defaults_show_mark_as_paid_config.sql @@ -0,0 +1,9 @@ +-- @tag: defaults_show_mark_as_paid_config +-- @description: Einstellung, ob der "als bezahlt markieren"-Knopf angezeigt wird. +-- @depends: release_2_7_0 +-- @charset: utf-8 + +ALTER TABLE defaults ADD COLUMN is_show_mark_as_paid boolean DEFAULT TRUE; +ALTER TABLE defaults ADD COLUMN ir_show_mark_as_paid boolean DEFAULT TRUE; +ALTER TABLE defaults ADD COLUMN ar_show_mark_as_paid boolean DEFAULT TRUE; +ALTER TABLE defaults ADD COLUMN ap_show_mark_as_paid boolean DEFAULT TRUE; diff --git a/t/README b/t/README deleted file mode 100644 index 07276f3f5..000000000 --- a/t/README +++ /dev/null @@ -1,41 +0,0 @@ -Testsuite for Lx-Office. - -These tests are a means to ensure basic sanity among the lx-office source -files. The test framework was originally written by the guys of Bugzilla, and -has been modified to cope with the Lx-Office structure. - -To run a full test use the shell script t/test.sh. -You can also run every test with the perl interpreter like this: - -$ perl t/001compile.t - -A makefile for an automated make test would be highly appreciated. - - - -The Tests: - -001compile.t: Tries to compile every source file. Bails out if any errors occur. -002goodperl.t: Checks every perl source file for taint, warnings and strict. - While taint is not seen mandatory, warnings and strict are. -003safesys: Checks is system() and exec() calls are fully qualified. -004template.t defunct! -005no_tabs.t checks every file for the \t Tab char. don't use tabs please. -006spelling.t checks for common spelling errors. -011pod.t checks if POD syntax is correct. - - -Wanted Tests: - -- module check -- check if symlinks are missing. -- check for anything outside lower ascii in pl/pm files (only place for complex - coding is locale) -- check for msdos line endings -- check for trailing whitespace -- Devise a test to check if there are modifications to locales without a - locales.pl run. -- Test if parse_template can compile all html templates. - -and later: -- spec tests for pure backend modules like Form.pm and Common.pm diff --git a/t/background_job/known_jobs.t b/t/background_job/known_jobs.t new file mode 100644 index 000000000..c6b43f0e6 --- /dev/null +++ b/t/background_job/known_jobs.t @@ -0,0 +1,13 @@ +use Test::More tests => 4; + +use lib 't'; + +use Support::TestSetup; + +use_ok 'SL::BackgroundJob::Base'; + +my @expected_known_job_classes = qw(CleanBackgroundJobHistory CreatePeriodicInvoices SelfTest Test); +is_deeply [ SL::BackgroundJob::Base->get_known_job_classes ], \@expected_known_job_classes, 'get_known_job_classes called as class method'; + +my $job = new_ok 'SL::BackgroundJob::Base'; +is_deeply [ $job->get_known_job_classes ], \@expected_known_job_classes, 'get_known_job_classes called as instance method'; diff --git a/t/test.sh b/t/test.sh index 761f9021f..f5b031a59 100755 --- a/t/test.sh +++ b/t/test.sh @@ -1 +1,9 @@ -find t | grep "\.t$" | grep -v '^t/old' | HARNESS_OPTIONS=j:c xargs perl -Imodules/override -MTest::Harness -e 'BEGIN { push @INC, "modules/fallback" } runtests(@ARGV)' +#!/bin/bash + +{ + if [[ -z $1 ]]; then + find t -type f -name '*.t' + else + echo -- "$@" + fi +} | HARNESS_OPTIONS=j:c xargs perl -Imodules/override -MTest::Harness -e 'BEGIN { push @INC, "modules/fallback" } runtests(@ARGV)' diff --git a/templates/webpages/ap/form_footer.html b/templates/webpages/ap/form_footer.html index 8ac37eca6..2408d5245 100644 --- a/templates/webpages/ap/form_footer.html +++ b/templates/webpages/ap/form_footer.html @@ -42,7 +42,9 @@ [%- IF id %] - + [% IF INSTANCE_CONF.get_ap_show_mark_as_paid %] + + [% END %] [%- END %] diff --git a/templates/webpages/background_job/form.html b/templates/webpages/background_job/form.html index 90eecd099..5e02ea1ef 100644 --- a/templates/webpages/background_job/form.html +++ b/templates/webpages/background_job/form.html @@ -24,7 +24,7 @@
    [%- LxERP.t8('Package name') %][% L.input_tag("background_job.package_name", SELF.background_job.package_name, 'size' => 40) %][% L.select_tag("background_job.package_name", JOB_CLASSES, 'default' => SELF.background_job.package_name) %]
    + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + +
    [% 'Posting Configuration' | $T8 %]
    [% 'Sales invoices changeable' | $T8 %][% L.select_tag('is_changeable', SELF.posting_options, value_key => 'value', title_key => 'title', default => SELF.is_changeable) %][% 'Should sales invoices be and when should they be changeable or deleteable after posting?' | $T8 %]
    [% 'Purchase invoices changeable' | $T8 %][% L.select_tag('ir_changeable', SELF.posting_options, value_key => 'value', title_key => 'title', default => SELF.ir_changeable) %][% 'Should purchase invoices be and when should they be deleteable after posting?' | $T8 %]
    [% 'AR transactions changeable' | $T8 %][% L.select_tag('ar_changeable', SELF.posting_options, value_key => 'value', title_key => 'title', default => SELF.ar_changeable) %][% 'Should ar transactions be and when should they be changeable or deleteable after posting?' | $T8 %]
    [% 'AP transactions changeable' | $T8 %][% L.select_tag('ap_changeable', SELF.posting_options, value_key => 'value', title_key => 'title', default => SELF.ap_changeable) %][% 'Should ap transactions be and when should they be changeable or deleteable after posting?' | $T8 %]
    [% 'GL transactions changeable' | $T8 %][% L.select_tag('gl_changeable', SELF.posting_options, value_key => 'value', title_key => 'title', default => SELF.gl_changeable) %][% 'Should gl transactions be and when should they be changeable or deleteable after posting?' | $T8 %]
    [% 'Payments Changeable' | $T8 %][% L.select_tag('payments_changeable', SELF.payment_options, value_key => 'value', title_key => 'title', default => SELF.payments_changeable) %][% 'Should payments be and when should they be changeable after posting?' | $T8 %]
    [% 'Show "mark as paid" in sales invoices' | $T8 %][% L.yes_no_tag('is_show_mark_as_paid', SELF.is_show_mark_as_paid) %][% 'Should the "mark as paid" button showed on sales invoices?' | $T8 %]
    [% 'Show "mark as paid" in purchase invoices' | $T8 %][% L.yes_no_tag('ir_show_mark_as_paid', SELF.ir_show_mark_as_paid) %][% 'Should the "mark as paid" button showed in purchase invoices?' | $T8 %]
    [% 'Show "mark as paid" in ar transactions' | $T8 %][% L.yes_no_tag('ar_show_mark_as_paid', SELF.ar_show_mark_as_paid) %][% 'Should the "mark as paid" button showed in ar transactions?' | $T8 %]
    [% 'Show "mark as paid" in ap transactions' | $T8 %][% L.yes_no_tag('ap_show_mark_as_paid', SELF.ap_show_mark_as_paid) %][% 'Should the "mark as paid" button showed in ap transactions?' | $T8 %]
    [% 'Accounting method' | $T8 %][% L.select_tag('accounting_method', SELF.accounting_options, value_key => 'value', title_key => 'title', default => SELF.accounting_method) %][% 'This option controls the posting and calculation behavior for the accounting method.' | $T8 %]
    [% 'Inventory system' | $T8 %][% L.select_tag('inventory_system', SELF.inventory_options, value_key => 'value', title_key => 'title', default => SELF.inventory_system) %] + [% 'This option controls the inventory system.' | $T8 %]
    + [% 'ATTENTION! You can not simply change it from periodic to perpetual once you started posting.' | $T8 %] +
    [% 'Profit determination' | $T8 %][% L.select_tag('profit_determination', SELF.profit_options, value_key => 'value', title_key => 'title', default => SELF.profit_determination) %][% 'This option controls the method used for profit determination.' | $T8 %]
    [% 'DATEV check configuration' | $T8 %]
    [% 'It is possible to make a quick DATEV export everytime you post a record to ensure things work nicely with their data requirements. This will result in a slight overhead though you can enable this for each type of record independantly.' | $T8 %]
    [% 'Check on sales invoice' | $T8 %][% L.yes_no_tag('datev_check_on_sales_invoice', SELF.datev_check_on_sales_invoice) %][% 'Perform check when a sales invoice or a payment for a sales invoice is posted?' | $T8 %]
    [% 'Check on purchase invoice' | $T8 %][% L.yes_no_tag('datev_check_on_purchase_invoice', SELF.datev_check_on_purchase_invoice) %][% 'Perform check when a purchase invoice or a payment for a purchase invoice is posted?' | $T8 %]
    [% 'Check on ar transaction' | $T8 %][% L.yes_no_tag('datev_check_on_ar_transaction', SELF.datev_check_on_ar_transaction) %][% 'Perform check when an ar transaction is posted?' | $T8 %]
    [% 'Check on ap transaction' | $T8 %][% L.yes_no_tag('datev_check_on_ap_transaction', SELF.datev_check_on_ap_transaction) %][% 'Perform check when an ap transaction is posted?' | $T8 %]
    [% 'Check on gl transaction' | $T8 %][% L.yes_no_tag('datev_check_on_gl_transaction', SELF.datev_check_on_gl_transaction) %][% 'Perform check when a gl transaction is posted?' | $T8 %]
    [% 'Orders / Delivery Orders deleteable' | $T8 %]
    [% 'Sales Orders deleteable' | $T8 %][% L.yes_no_tag('sales_order_show_delete', SELF.sales_order_show_delete) %][% 'Show delete button in sales orders?' | $T8 %]
    [% 'Purchase Orders deleteable' | $T8 %][% L.yes_no_tag('purchase_order_show_delete', SELF.purchase_order_show_delete) %][% 'Show delete button in purchase orders?' | $T8 %]
    [% 'Sales Delivery Orders deleteable' | $T8 %][% L.yes_no_tag('sales_delivery_order_show_delete', SELF.sales_delivery_order_show_delete) %][% 'Show delete button in sales delivery orders?' | $T8 %]
    [% 'Purchase Delivery Orders deleteable' | $T8 %][% L.yes_no_tag('purchase_delivery_order_show_delete', SELF.purchase_delivery_order_show_delete) %][% 'Show delete button in purchase delivery orders?' | $T8 %]
    [% 'Warehouse' | $T8 %]
    [% 'Show Bestbefore' | $T8 %] + [% L.yes_no_tag('show_bestbefore', SELF.show_bestbefore) %] + + [% 'Show fields used for the best before date?' | $T8 %]
    + [% 'ATTENTION! If you enabled this feature you can not simply turn it off again without taking care that best_before fields are emptied in the database.' | $T8 %]
    + [% 'This can be done with the following query:' | $T8 %]
    +
    + UPDATE inventory SET bestbefore = NULL;
    +
    + [% 'Any stock contents containing a best before date will be impossible to stock out otherwise.' | $T8 %] +
    + +
    + +[%- L.hidden_tag('action', 'ClientConfig/dispatch') %] +[%- L.submit_tag('action_save', LxERP.t8('Save')) %] + +

    + + diff --git a/templates/webpages/common/show_vc_details.html b/templates/webpages/common/show_vc_details.html index 89c2f4599..be6406bce 100644 --- a/templates/webpages/common/show_vc_details.html +++ b/templates/webpages/common/show_vc_details.html @@ -2,6 +2,7 @@ [% USE HTML %] [% BLOCK jump_block %] +[%- IF SHIPTO.size || CONTACTS.size %]

    [% 'Jump to' | $T8 %] [% 'Billing Address' | $T8 %] [%- FOREACH shipto = SHIPTO %] @@ -21,6 +22,7 @@


    +[%- END %] [% END %] @@ -323,4 +325,3 @@
    [% END %] - diff --git a/templates/webpages/do/form_footer.html b/templates/webpages/do/form_footer.html index a37e94239..364367b92 100644 --- a/templates/webpages/do/form_footer.html +++ b/templates/webpages/do/form_footer.html @@ -82,8 +82,8 @@

    [% 'Workflow Delivery Order' | $T8 %]
    - [% UNLESS delivered %] - + [% UNLESS delivered || (vc == 'customer' && !INSTANCE_CONF.get_sales_delivery_order_show_delete) || (vc == 'vendor' && !INSTANCE_CONF.get_purchase_delivery_order_show_delete) %] + [% END %]

    diff --git a/templates/webpages/do/stock_in_form.html b/templates/webpages/do/stock_in_form.html index 27457f310..99b5db1e2 100644 --- a/templates/webpages/do/stock_in_form.html +++ b/templates/webpages/do/stock_in_form.html @@ -93,7 +93,7 @@ [% 'Warehouse' | $T8 %] [% 'Bin' | $T8 %] [% 'Charge Number' | $T8 %] - [% IF conf_show_best_before %] + [% IF INSTANCE_CONF.get_show_bestbefore %] [% 'Best Before' | $T8 %] [% END %] [% 'Qty' | $T8 %] @@ -109,7 +109,7 @@ [% HTML.escape(row.warehouse_description) %] [% HTML.escape(row.bin_description) %] [% HTML.escape(row.chargenumber) %] - [% IF conf_show_best_before %] + [% IF INSTANCE_CONF.get_show_bestbefore %] [% HTML.escape(row.bestbefore) %] [% END %] [% HTML.escape(LxERP.format_amount(row.qty)) %] @@ -127,7 +127,7 @@ - [% IF conf_show_best_before %] + [% IF INSTANCE_CONF.get_show_bestbefore %] [% L.date_tag('bestbefore_'_ loop.count, row.bestbefore) %] diff --git a/templates/webpages/do/stock_out_form.html b/templates/webpages/do/stock_out_form.html index 6aee3510f..06b599038 100644 --- a/templates/webpages/do/stock_out_form.html +++ b/templates/webpages/do/stock_out_form.html @@ -61,7 +61,7 @@ [% 'Warehouse' | $T8 %] [% 'Bin' | $T8 %] [% 'Charge Number' | $T8 %] - [% IF conf_show_best_before %] + [% IF INSTANCE_CONF.get_show_bestbefore %] [% 'Best Before' | $T8 %] [% END %] [%- UNLESS delivered %] @@ -77,7 +77,7 @@ [% HTML.escape(row.warehousedescription) %] [% HTML.escape(row.bindescription) %] [% HTML.escape(row.chargenumber) %] - [% IF conf_show_best_before %] + [% IF INSTANCE_CONF.get_show_bestbefore %] [% HTML.escape(row.bestbefore) %] [% END %] [%- IF delivered %] @@ -109,7 +109,7 @@ - [% IF conf_show_best_before %] + [% IF INSTANCE_CONF.get_show_bestbefore %] [% END %] [%- END %] diff --git a/templates/webpages/generic/select_part.html b/templates/webpages/generic/select_part.html index f08104146..ddf5511c8 100644 --- a/templates/webpages/generic/select_part.html +++ b/templates/webpages/generic/select_part.html @@ -21,7 +21,7 @@ [% 'Charge number' | $T8 %] [% END %] [% IF has_bestbefore %] - [% IF conf_show_best_before %] + [% IF INSTANCE_CONF.get_show_bestbefore %] [% 'Best Before' | $T8 %] [% END %] [% END %] @@ -55,7 +55,7 @@ [% END %] [% IF has_bestbefore %] - [% IF conf_show_best_before %] + [% IF INSTANCE_CONF.get_show_bestbefore %] diff --git a/templates/webpages/ir/form_footer.html b/templates/webpages/ir/form_footer.html index 2f255f788..b2732a7ce 100644 --- a/templates/webpages/ir/form_footer.html +++ b/templates/webpages/ir/form_footer.html @@ -116,7 +116,9 @@ [%#- button for saving history %] - + [% IF INSTANCE_CONF.get_ir_show_mark_as_paid %] + + [% END %] [% END %] diff --git a/templates/webpages/is/form_footer.html b/templates/webpages/is/form_footer.html index 6cbcd4ef1..ee093dc95 100644 --- a/templates/webpages/is/form_footer.html +++ b/templates/webpages/is/form_footer.html @@ -157,8 +157,9 @@ [% IF id %] [%#- button for saving history %] - - + [% IF INSTANCE_CONF.get_is_show_mark_as_paid %] + + [% END %] [% END %] diff --git a/templates/webpages/login_screen/auth_db_needs_update.html b/templates/webpages/login_screen/auth_db_needs_update.html index a92c7c3ac..5ea301b5a 100644 --- a/templates/webpages/login_screen/auth_db_needs_update.html +++ b/templates/webpages/login_screen/auth_db_needs_update.html @@ -3,15 +3,15 @@

    [% LxERP.t8('Error!') %]

    - [% LxERP.t8('Kivitendo needs to update the authentication database before you can proceed.') %] + [% LxERP.t8('kivitendo needs to update the authentication database before you can proceed.') %] [% LxERP.t8('Please log in to the administration panel.') %] - [% LxERP.t8('Kivitendo will then update the database automatically.') %] + [% LxERP.t8('kivitendo will then update the database automatically.') %]


    - [% LxERP.t8('For further information read this: ') %] Kivitendo Installation
    - [% LxERP.t8('Or download the whole Installation Documentation as PDF (350kB) for off-line study (currently in German Language): ') %] Kivitendo-Dokumentation.pdf + [% LxERP.t8('For further information read this: ') %] kivitendo Installation
    + [% LxERP.t8('Or download the whole Installation Documentation as PDF (350kB) for off-line study (currently in German Language): ') %] kivitendo-Dokumentation.pdf


    @@ -20,4 +20,3 @@ [% LxERP.t8('Login') %] | [% LxERP.t8('Administration') %]

    - diff --git a/templates/webpages/login_screen/auth_db_unreachable.html b/templates/webpages/login_screen/auth_db_unreachable.html index 556cd014d..a9aad3515 100644 --- a/templates/webpages/login_screen/auth_db_unreachable.html +++ b/templates/webpages/login_screen/auth_db_unreachable.html @@ -7,7 +7,7 @@

    [% 'If you want to set up the authentication database yourself then log in to the administration panel. kivitendo will then create the database and tables for you.' | $T8 %]


    [% 'For further information read this: ' | $T8 %] kivitendo Installation
    - [% 'Or download the whole Installation Documentation as PDF (350kB) for off-line study (currently in German Language): ' | $T8 %] Kivitendo-Dokumentation.pdf

    + [% 'Or download the whole Installation Documentation as PDF (350kB) for off-line study (currently in German Language): ' | $T8 %] kivitendo-Dokumentation.pdf


    @@ -15,4 +15,3 @@ [% 'Login' | $T8 %] | [% 'Administration' | $T8 %]

    - diff --git a/templates/webpages/login_screen/old_configuration_files.html b/templates/webpages/login_screen/old_configuration_files.html index f65b6a25e..36ef4d40f 100644 --- a/templates/webpages/login_screen/old_configuration_files.html +++ b/templates/webpages/login_screen/old_configuration_files.html @@ -21,7 +21,7 @@

    - [%- LxERP.t8('Which is located at doc/Kivitendo-Dokumentation.pdf. Click here: ') %] doc/Kivitendo-Dokumentation.pdf + [%- LxERP.t8('Which is located at doc/kivitendo-Dokumentation.pdf. Click here: ') %] doc/kivitendo-Dokumentation.pdf

    diff --git a/templates/webpages/oe/form_footer.html b/templates/webpages/oe/form_footer.html index ddf4a53d2..f83334c44 100644 --- a/templates/webpages/oe/form_footer.html +++ b/templates/webpages/oe/form_footer.html @@ -146,7 +146,10 @@
    [% label_workflow %]
    - + + [%- UNLESS (is_sales_ord && !INSTANCE_CONF.get_sales_order_show_delete) || (is_pur_ord && !INSTANCE_CONF.get_purchase_order_show_delete) %] + + [%- END %] [%- IF is_sales_quo %] diff --git a/templates/webpages/wh/journal_filter.html b/templates/webpages/wh/journal_filter.html index 36740581e..e6082cd9c 100644 --- a/templates/webpages/wh/journal_filter.html +++ b/templates/webpages/wh/journal_filter.html @@ -105,7 +105,7 @@ [% 'Charge Number' | $T8 %]: - [% IF conf_show_best_before %] + [% IF INSTANCE_CONF.get_show_bestbefore %] [% 'Best Before' | $T8 %]: @@ -166,7 +166,7 @@ - [% IF conf_show_best_before %] + [% IF INSTANCE_CONF.get_show_bestbefore %] [% END %] diff --git a/templates/webpages/wh/removal_parts_selection.html b/templates/webpages/wh/removal_parts_selection.html index 837023ed3..5cf5ffa35 100644 --- a/templates/webpages/wh/removal_parts_selection.html +++ b/templates/webpages/wh/removal_parts_selection.html @@ -35,7 +35,7 @@ [% 'Part Number' | $T8 %] [% 'Part Description' | $T8 %] [% 'Charge Number' | $T8 %] - [% IF conf_show_best_before %] + [% IF INSTANCE_CONF.get_show_bestbefore %] [% 'Best Before' | $T8 %] [% END %] [% 'EAN' | $T8 %] @@ -50,7 +50,7 @@ - [% IF conf_show_best_before %] + [% IF INSTANCE_CONF.get_show_bestbefore %] [% END %] @@ -58,7 +58,7 @@ [% HTML.escape(row.partnumber) %] [% HTML.escape(row.partdescription) %] [% HTML.escape(row.chargenumber) %] - [% IF conf_show_best_before %] + [% IF INSTANCE_CONF.get_show_bestbefore %] [% HTML.escape(row.bestbefore) %] [% END %] [% HTML.escape(row.ean) %] diff --git a/templates/webpages/wh/report_filter.html b/templates/webpages/wh/report_filter.html index 77a5070be..12a3e0b60 100644 --- a/templates/webpages/wh/report_filter.html +++ b/templates/webpages/wh/report_filter.html @@ -105,7 +105,7 @@ [% 'Charge Number' | $T8 %]: - [% IF conf_show_best_before %] + [% IF INSTANCE_CONF.get_show_bestbefore %] [% 'Best Before' | $T8 %]: @@ -160,7 +160,7 @@ - [% IF conf_show_best_before %] + [% IF INSTANCE_CONF.get_show_bestbefore %] [% END %] diff --git a/templates/webpages/wh/transfer_parts_selection.html b/templates/webpages/wh/transfer_parts_selection.html index e026dc614..62ded76ff 100644 --- a/templates/webpages/wh/transfer_parts_selection.html +++ b/templates/webpages/wh/transfer_parts_selection.html @@ -66,7 +66,7 @@ [% 'Part Number' | $T8 %] [% 'Part Description' | $T8 %] [% 'Charge Number' | $T8 %] - [% IF conf_show_best_before %] + [% IF INSTANCE_CONF.get_show_bestbefore %] [% 'Best Before' | $T8 %] [% END %] [% 'EAN' | $T8 %] @@ -82,7 +82,7 @@ - [% IF conf_show_best_before %] + [% IF INSTANCE_CONF.get_show_bestbefore %] [% END %] @@ -90,7 +90,7 @@ [% HTML.escape(row.partnumber) %] [% HTML.escape(row.partdescription) %] [% HTML.escape(row.chargenumber) %] - [% IF conf_show_best_before %] + [% IF INSTANCE_CONF.get_show_bestbefore %] [% HTML.escape(row.bestbefore) %] [% END %] [% HTML.escape(row.ean) %] diff --git a/templates/webpages/wh/warehouse_selection.html b/templates/webpages/wh/warehouse_selection.html index 29ffe751c..429b3b1e6 100644 --- a/templates/webpages/wh/warehouse_selection.html +++ b/templates/webpages/wh/warehouse_selection.html @@ -118,7 +118,7 @@ - [% IF conf_show_best_before %] + [% IF INSTANCE_CONF.get_show_bestbefore %] [% 'Best Before' | $T8 %] diff --git a/templates/webpages/wh/warehouse_selection_assembly.html b/templates/webpages/wh/warehouse_selection_assembly.html index 394450c76..4fb3a715f 100644 --- a/templates/webpages/wh/warehouse_selection_assembly.html +++ b/templates/webpages/wh/warehouse_selection_assembly.html @@ -106,7 +106,7 @@ - [% IF conf_show_best_before %] + [% IF INSTANCE_CONF.get_show_bestbefore %] [% 'Best Before' | $T8 %] diff --git a/templates/webpages/wh/warehouse_selection_stock.html b/templates/webpages/wh/warehouse_selection_stock.html index bdff7961d..50da3f1e2 100644 --- a/templates/webpages/wh/warehouse_selection_stock.html +++ b/templates/webpages/wh/warehouse_selection_stock.html @@ -106,7 +106,7 @@ - [% IF conf_show_best_before %] + [% IF INSTANCE_CONF.get_show_bestbefore %] [% 'Best Before' | $T8 %]