X-Git-Url: http://wagnertech.de/git?a=blobdiff_plain;f=SL%2FUser.pm;h=593707c82c0523e9ce9ec4b5f357bf75487feca2;hb=31f989254ce9f2ab881af7aee5d07dd63df0e004;hp=45f5f553d7df91bfa13ea399698767f9f0486e9a;hpb=a9da5102a870336ee4d347117ca7a33eeaff64ea;p=kivitendo-erp.git diff --git a/SL/User.pm b/SL/User.pm index 45f5f553d..593707c82 100644 --- a/SL/User.pm +++ b/SL/User.pm @@ -25,7 +25,8 @@ # GNU General Public License for more details. # You should have received a copy of the GNU General Public License # along with this program; if not, write to the Free Software -# Foundation, Inc., 675 Mass Ave, Cambridge, MA 02139, USA. +# Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, +# MA 02110-1335, USA. #===================================================================== # # user related functions @@ -37,6 +38,7 @@ package User; use IO::File; use Fcntl qw(:seek); +use SL::DB; #use SL::Auth; use SL::DB::AuthClient; use SL::DB::Employee; @@ -113,7 +115,7 @@ sub login { return LOGIN_AUTH_DBUPDATE_AVAILABLE() if $dbupdater_auth->unapplied_upgrade_scripts($::auth->dbconnect); # check if database is down - my $dbh = $form->dbconnect_noauto; + my $dbh = SL::DB->client->dbh; # we got a connection, check the version my ($dbversion) = $dbh->selectrow_array(qq|SELECT version FROM defaults|); @@ -126,13 +128,18 @@ sub login { my $dbupdater = SL::DBUpgrade2->new(form => $form)->parse_dbupdate_controls; my @unapplied_scripts = $dbupdater->unapplied_upgrade_scripts($dbh); - $dbh->disconnect; +# $dbh->disconnect; if (!@unapplied_scripts) { SL::DB::Manager::Employee->update_entries_for_authorized_users; return LOGIN_OK(); } + # Store the fact that we're applying database upgrades at the + # moment. That way functions called from the layout modules that may + # require updated tables can chose only to use basic features. + $::request->applying_database_upgrades(1); + $form->{$_} = $::auth->client->{$_} for qw(dbname dbhost dbport dbuser dbpasswd); $form->{$_} = $myconfig{$_} for qw(datestyle); @@ -144,7 +151,7 @@ sub login { if ($form->{"show_dbupdate_warning"}) { print $form->parse_html_template("dbupgrade/warning", { unapplied_scripts => \@unapplied_scripts }); - ::end_of_request(); + $::dispatcher->end_request; } # update the tables @@ -159,7 +166,7 @@ sub login { # 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 + # $::dispatcher->end_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 @@ -307,13 +314,29 @@ sub dbcreate { $curr = selectfirst_hashref_query($form, $dbh, $query, $form->{defaultcurrency}); } - $query = qq|UPDATE defaults SET accounting_method = ?, profit_determination = ?, inventory_system = ?, precision = ?, currency_id = ?|; + $query = qq|UPDATE defaults SET + accounting_method = ?, + profit_determination = ?, + inventory_system = ?, + precision = ?, + currency_id = ?, + feature_balance = ?, + feature_datev = ?, + feature_erfolgsrechnung = ?, + feature_eurechnung = ?, + feature_ustva = ? + |; do_query($form, $dbh, $query, $form->{accounting_method}, $form->{profit_determination}, $form->{inventory_system}, $form->parse_amount(\%::myconfig, $form->{precision_as_number}), $curr->{id}, + $form->{feature_balance}, + $form->{feature_datev}, + $form->{feature_erfolgsrechnung}, + $form->{feature_eurechnung}, + $form->{feature_ustva} ); $dbh->disconnect; @@ -412,9 +435,6 @@ sub dbupdate2 { &dbconnect_vars($form, $db); - # Flush potentially held database locks. -# $form->get_standard_dbh->commit; - my $dbh = SL::DBConnect->connect($form->{dbconnect}, $form->{dbuser}, $form->{dbpasswd}, SL::DBConnect->get_options) or $form->dberror; $dbh->do($form->{dboptions}) if ($form->{dboptions}); @@ -449,7 +469,7 @@ sub get_default_myconfig { css_path => 'css', # Needed for menunew, see SL::Layout::Base::get_stylesheet_for_user dateformat => $defaults->dateformat('dd.mm.yy'), numberformat => $defaults->numberformat('1.000,00'), - stylesheet => 'kivitendo.css', + stylesheet => $defaults->stylesheet('kivitendo.css'), timeformat => $defaults->timeformat('hh:mm'), %user_config, );