X-Git-Url: http://wagnertech.de/git?a=blobdiff_plain;f=SL%2FUser.pm;h=8bb9b997bd68475b7518ad4fe1b9fa2e86a165dc;hb=013804fdf4b69b04889d8bf8af182eda9e9d95a5;hp=a2782390864d7147f9462cc697ac423214fbe943;hpb=6ca9244cdf323b4ad216ce69e7b9516f8423b344;p=kivitendo-erp.git diff --git a/SL/User.pm b/SL/User.pm index a27823908..8bb9b997b 100644 --- a/SL/User.pm +++ b/SL/User.pm @@ -39,6 +39,7 @@ use Fcntl qw(:seek); #use SL::Auth; use SL::DB::AuthClient; +use SL::DB::Employee; use SL::DBConnect; use SL::DBUpgrade2; use SL::DBUtils; @@ -126,7 +127,10 @@ sub login { my $update_available = $dbupdater->update2_available($dbh); $dbh->disconnect; - return LOGIN_OK() if !$update_available; + if (!$update_available) { + SL::DB::Manager::Employee->update_entries_for_authorized_users; + return LOGIN_OK(); + } $form->{$_} = $::auth->client->{$_} for qw(dbname dbhost dbport dbuser dbpasswd); $form->{$_} = $myconfig{$_} for qw(datestyle); @@ -150,7 +154,16 @@ sub login { $SIG{QUIT} = 'IGNORE'; $self->dbupdate2(form => $form, updater => $dbupdater, database => $::auth->client->{dbname}); - SL::DBUpgrade2->new(form => $::form, auth => 1)->apply_admin_dbupgrade_scripts(0); + + # If $self->dbupdate2 returns than this means all upgrade scripts + # have been applied successfully, none required user + # interaction. Otherwise the deeper layers would have called + # ::end_of_request() already, and return would not have returned to + # us. Therefore we can now use RDBO instances because their supposed + # table structures do match the actual structures. So let's ensure + # that the "employee" table contains the appropriate entries for all + # users authorized for the current client. + SL::DB::Manager::Employee->update_entries_for_authorized_users; SL::System::InstallationLock->unlock; @@ -273,7 +286,7 @@ sub dbcreate { # load chart of accounts $dbupdater->process_query($dbh, "sql/$form->{chart}-chart.sql"); - my $query = qq|UPDATE defaults SET coa = ?, accounting_method = ?, profit_determination = ?, inventory_system = ?, curr = ?|; + $query = qq|UPDATE defaults SET coa = ?, accounting_method = ?, profit_determination = ?, inventory_system = ?, curr = ?|; do_query($form, $dbh, $query, map { $form->{$_} } qw(chart accounting_method profit_determination inventory_system defaultcurrency)); $dbh->disconnect; @@ -298,27 +311,6 @@ sub dbdelete { $main::lxdebug->leave_sub(); } -sub dbsources_unused { - $main::lxdebug->enter_sub(); - - my ($self, $form) = @_; - - my %dbexcl = map { $_->dbname => 1 } - grep { ($_->dbhost eq $form->{dbhost}) && ($_->dbport eq $form->{dbport}) } - @{ SL::DB::Manager::AuthClient->get_all }; - - $form->{only_acc_db} = 1; - - $dbexcl{$form->{dbdefault}} = 1; - $dbexcl{$main::auth->{DB_config}->{db}} = 1; - - my @dbunused = grep { !$dbexcl{$_} } dbsources("", $form); - - $main::lxdebug->leave_sub(); - - return @dbunused; -} - sub calc_version { $main::lxdebug->enter_sub(2); @@ -341,7 +333,7 @@ sub calc_version { sub cmp_script_version { my ($a_from, $a_to, $b_from, $b_to); my ($i, $res_a, $res_b); - my ($my_a, $my_b) = ($a, $b); + my ($my_a, $my_b) = do { no warnings 'once'; ($a, $b) }; $my_a =~ s/.*-upgrade-//; $my_a =~ s/.sql$//; @@ -382,14 +374,11 @@ sub create_schema_info_table { } sub dbupdate2 { - $main::lxdebug->enter_sub(); - my ($self, %params) = @_; my $form = $params{form}; my $dbupdater = $params{updater}; my $db = $params{database}; - my $rc = -2; map { $_->{description} = SL::Iconv::convert($_->{charset}, 'UTF-8', $_->{description}) } values %{ $dbupdater->{all_controls} }; @@ -403,22 +392,17 @@ sub dbupdate2 { my @upgradescripts = $dbupdater->unapplied_upgrade_scripts($dbh); - $dbh->disconnect and next if !@upgradescripts; - foreach my $control (@upgradescripts) { - # apply upgrade + # Apply upgrade. Control will only return to us if the upgrade has + # been applied correctly and if the update has not requested user + # interaction. $main::lxdebug->message(LXDebug->DEBUG2(), "Applying Update $control->{file}"); print $form->parse_html_template("dbupgrade/upgrade_message2", $control); $dbupdater->process_file($dbh, "sql/Pg-upgrade2/$control->{file}", $control); } - $rc = 0; $dbh->disconnect; - - $main::lxdebug->leave_sub(); - - return $rc; } sub data {