X-Git-Url: http://wagnertech.de/git?a=blobdiff_plain;f=bin%2Fmozilla%2Fadmin.pl;h=5f3e0b19d8f2e95406aa48c8c58a48ba1e65a30a;hb=16455a4f7a2e871d645485ffb5904d197b907217;hp=e478d6ba1f68e86c657c61b9711272ef8b7856c2;hpb=2d6988532a665bd7e42bb88a38a8b52cbb352646;p=kivitendo-erp.git diff --git a/bin/mozilla/admin.pl b/bin/mozilla/admin.pl old mode 100644 new mode 100755 index e478d6ba1..5f3e0b19d --- a/bin/mozilla/admin.pl +++ b/bin/mozilla/admin.pl @@ -32,1311 +32,498 @@ # #====================================================================== -$menufile = "menu.ini"; - use DBI; -use CGI; - +use Encode; +use English qw(-no_match_vars); +use Fcntl; +use File::Copy; +use File::Find; +use File::Spec; +use Cwd; +use IO::Dir; +use IO::File; +use POSIX qw(strftime); +use Sys::Hostname; + +use SL::Auth; +use SL::Auth::PasswordPolicy; +use SL::DB::AuthClient; +use SL::DB::AuthUser; use SL::Form; +use SL::Iconv; +use SL::Mailer; use SL::User; use SL::Common; +use SL::Inifile; +use SL::DBUpgrade2; +use SL::DBUtils; +use SL::Template; require "bin/mozilla/common.pl"; -our $cgi = new CGI(''); +use strict; -$form = new Form; -$form->{"root"} = "root login"; +# parserhappy(R): -$locale = new Locale $language, "admin"; +# $locale->text('periodic') +# $locale->text('income') +# $locale->text('perpetual') +# $locale->text('balance') -# customization -if (-f "bin/mozilla/custom_$form->{script}") { - eval { require "bin/mozilla/custom_$form->{script}"; }; - $form->error($@) if ($@); -} +our $cgi; +our $form; +our $locale; +our $auth; -$form->{stylesheet} = "lx-office-erp.css"; -$form->{favicon} = "favicon.ico"; +sub run { + $::lxdebug->enter_sub; + my $session_result = shift; -if ($form->{action}) { + $form = $::form; + $locale = $::locale; + $auth = $::auth; + $::request->{layout} = SL::Layout::Dispatcher->new(style => 'admin'); + $::request->{layout}->use_stylesheet("lx-office-erp.css"); + $form->{favicon} = "favicon.ico"; - $subroutine = $locale->findsub($form->{action}); + if ($form->{action}) { + if ($auth->authenticate_root($form->{'{AUTH}admin_password'}) != $auth->OK()) { + $auth->punish_wrong_login; + $form->{error} = $locale->text('Incorrect password!'); + $auth->delete_session_value('admin_password'); + adminlogin(); + } else { + if ($auth->session_tables_present()) { + delete $::form->{'{AUTH}admin_password'}; + } - if ($subroutine eq 'login') { - if ($form->{rpw}) { - $form->{rpw} = crypt $form->{rpw}, "ro"; + call_sub($locale->findsub($form->{action})); } + } else { + adminlogin(); } - - &check_password; - - call_sub($subroutine); - -} else { - - # if there are no drivers bail out - $form->error($locale->text('No Database Drivers available!')) - unless (User->dbdrivers); - - # create memberfile - if (!-f $memberfile) { - open(FH, ">$memberfile") or $form->error("$memberfile : $!"); - print FH qq|# SQL-Ledger Accounting members - -[root login] -password= - -|; - close FH; - } - - &adminlogin; - + $::lxdebug->leave_sub; } -1; - -# end - sub adminlogin { - - $form->{title} = - qq|Lx-Office ERP $form->{version} | . $locale->text('Administration'); - - $form->header(); - print $form->parse_html_template('admin/adminlogin'); + print $::request->cgi->redirect('controller.pl?action=Admin/login'); } -sub login { - list_users(); +sub pg_database_administration { + my $form = $main::form; + dbselect_source(); } -sub list_users { - - $form->error($locale->text('File locked!')) if (-f "${memberfile}.LCK"); - - open(FH, "$memberfile") or $form->error("$memberfile : $!"); - - my %members; - - while () { - chomp; - - if (/^\[.*\]/) { - $login = $_; - $login =~ s/(\[|\])//g; - - $members{$login} = { "login" => $login }; - } - - if (/^([a-z]+)=(.*)/) { - $members{$login}->{$1} = $2; - } - } +sub dbselect_source { + my $form = $main::form; + my $locale = $main::locale; - close(FH); + $form->{dbport} = $::auth->{DB_config}->{port} || 5432; + $form->{dbuser} = $::auth->{DB_config}->{user} || 'lxoffice'; + $form->{dbdefault} = 'template1'; + $form->{dbhost} = $::auth->{DB_config}->{host} || 'localhost'; - delete $members{"root login"}; - map { $_->{templates} =~ s|.*/||; } values %members; + $form->{title} = "kivitendo / " . $locale->text('Database Administration'); - $form->{title} = "Lx-Office ERP " . $locale->text('Administration'); - $form->{LOCKED} = -e "$userspath/nologin"; - $form->{MEMBERS} = [ @members{sort { lc $a cmp lc $b } keys %members} ]; + # Intentionnaly disabled unless fixed to work with the authentication DB. + $form->{ALLOW_DBBACKUP} = 0; # "$pg_dump_exe" ne "DISABLED"; $form->header(); - print $form->parse_html_template("admin/list_users"); + print $form->parse_html_template("admin/dbadmin"); } -sub add_user { - - $form->{title} = - "Lx-Office ERP " - . $locale->text('Administration') . " / " - . $locale->text('Add User'); - - $form->{Oracle_sid} = $sid; - $form->{Oracle_dbport} = '1521'; - $form->{Oracle_dbhost} = `hostname`; - - if (-f "css/lx-office-erp.css") { - $myconfig->{stylesheet} = "lx-office-erp.css"; - } - - $myconfig->{vclimit} = 200; - $myconfig->{countrycode} = "de"; - $myconfig->{numberformat} = "1000,00"; - $myconfig->{dateformat} = "dd.mm.yy"; - - &form_header; - &form_footer; - -} - -sub edit { - - $form->{title} = - "Lx-Office ERP " - . $locale->text('Administration') . " / " - . $locale->text('Edit User'); - $form->{edit} = 1; - - &form_header; - &form_footer; - +sub continue { + call_sub($main::form->{"nextsub"}); } -sub form_footer { - - if ($form->{edit}) { - $delete = - qq| -|; - } - - print qq| - - -{rpw}> - - -$delete +sub update_dataset { + my $form = $main::form; + my $locale = $main::locale; - + $form->{title} = "kivitendo " . $locale->text('Database Administration') . " / " . $locale->text('Update Dataset'); - - -|; + my @need_updates = User->dbneedsupdate($form); + $form->{NEED_UPDATES} = \@need_updates; + $form->{ALL_UPDATED} = !scalar @need_updates; + $form->header(); + print $form->parse_html_template("admin/update_dataset"); } -sub form_header { +sub dbupdate { + my $form = $main::form; + my $locale = $main::locale; - # if there is a login, get user - if ($form->{login}) { + $::request->{layout}->use_stylesheet("lx-office-erp.css"); + $form->{title} = $locale->text("Dataset upgrade"); + $form->header(); - # get user - $myconfig = new User "$memberfile", "$form->{login}"; + my $rowcount = $form->{rowcount} * 1; + my @update_rows = grep { $form->{"update_$_"} } (1 .. $rowcount); + $form->{NOTHING_TO_DO} = !scalar @update_rows; + my $saved_form = save_form(); - $myconfig->{signature} =~ s/\\n/\r\n/g; - $myconfig->{address} =~ s/\\n/\r\n/g; + $| = 1; - # strip basedir from templates directory - $myconfig->{templates} =~ s/^$templates\///; + print $form->parse_html_template("admin/dbupgrade_all_header"); - # $myconfig->{dbpasswd} = unpack 'u', $myconfig->{dbpasswd}; - } + foreach my $i (@update_rows) { + restore_form($saved_form); - foreach $item (qw(mm-dd-yy mm/dd/yy dd-mm-yy dd/mm/yy dd.mm.yy yyyy-mm-dd)) { - $dateformat .= - ($item eq $myconfig->{dateformat}) - ? "