use Fcntl qw(:seek);
#use SL::Auth;
+use SL::DB::AuthClient;
use SL::DBConnect;
use SL::DBUpgrade2;
use SL::DBUtils;
# we got a connection, check the version
my ($dbversion) = $dbh->selectrow_array(qq|SELECT version FROM defaults|);
- $self->create_employee_entry($form, $dbh, \%myconfig);
-
$self->create_schema_info_table($form, $dbh);
# Auth DB upgrades available?
my $dbupdater = SL::DBUpgrade2->new(form => $form)->parse_dbupdate_controls;
- $form->{$_} = $::auth->client->{$_} for qw(dbname dbhost dbport dbuser dbpasswd);
- $form->{$_} = $myconfig{$_} for qw(dateformat);
-
- dbconnect_vars($form, $form->{dbname});
-
my $update_available = $dbupdater->update_available($dbversion) || $dbupdater->update2_available($dbh);
$dbh->disconnect;
return 0 if !$update_available;
+
+ $form->{$_} = $::auth->client->{$_} for qw(dbname dbhost dbport dbuser dbpasswd);
+ $form->{$_} = $myconfig{$_} for qw(datestyle);
+
$form->{"title"} = $main::locale->text("Dataset upgrade");
$form->header(no_layout => $form->{no_layout});
print $form->parse_html_template("dbupgrade/header");
- $form->{dbupdate} = "db" . $form->{dbname};
+ $form->{dbupdate} = "db" . $::auth->client->{dbname};
if ($form->{"show_dbupdate_warning"}) {
print $form->parse_html_template("dbupgrade/warning");
$SIG{QUIT} = 'IGNORE';
$self->dbupdate($form);
- $self->dbupdate2($form, $dbupdater);
+ $self->dbupdate2(form => $form, updater => $dbupdater, database => $::auth->client->{dbname});
SL::DBUpgrade2->new(form => $::form, auth => 1)->apply_admin_dbupgrade_scripts(0);
SL::System::InstallationLock->unlock;
return @dbsources;
}
-sub dbclusterencoding {
- $main::lxdebug->enter_sub();
-
- my ($self, $form) = @_;
-
- $form->{dbdefault} ||= $form->{dbuser};
-
- dbconnect_vars($form, $form->{dbdefault});
-
- my $dbh = SL::DBConnect->connect($form->{dbconnect}, $form->{dbuser}, $form->{dbpasswd}, SL::DBConnect->get_options) || $form->dberror();
- my $query = qq|SELECT pg_encoding_to_char(encoding) FROM pg_database WHERE datname = 'template0'|;
- my ($cluster_encoding) = $dbh->selectrow_array($query);
- $dbh->disconnect();
-
- $main::lxdebug->leave_sub();
-
- return $cluster_encoding;
-}
-
sub dbcreate {
$main::lxdebug->enter_sub();
# load chart of accounts
$dbupdater->process_query($dbh, "sql/$form->{chart}-chart.sql", undef, $db_charset);
- $query = "UPDATE defaults SET coa = ?";
- do_query($form, $dbh, $query, $form->{chart});
- $query = "UPDATE defaults SET accounting_method = ?";
- do_query($form, $dbh, $query, $form->{accounting_method});
- $query = "UPDATE defaults SET profit_determination = ?";
- do_query($form, $dbh, $query, $form->{profit_determination});
- $query = "UPDATE defaults SET inventory_system = ?";
- do_query($form, $dbh, $query, $form->{inventory_system});
- $query = "UPDATE defaults SET curr = ?";
- do_query($form, $dbh, $query, $form->{defaultcurrency});
+ my $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;
my ($self, $form) = @_;
- $form->{only_acc_db} = 1;
+ my %dbexcl = map { $_->dbname => 1 }
+ grep { ($_->dbhost eq $form->{dbhost}) && ($_->dbport eq $form->{dbport}) }
+ @{ SL::DB::Manager::AuthClient->get_all };
- my %members = $main::auth->read_all_users();
- my %dbexcl = map { $_ => 1 } grep { $_ } map { $_->{dbname} } values %members;
+ $form->{only_acc_db} = 1;
$dbexcl{$form->{dbdefault}} = 1;
$dbexcl{$main::auth->{DB_config}->{db}} = 1;
return @dbunused;
}
-sub dbneedsupdate {
- $main::lxdebug->enter_sub();
-
- my ($self, $form) = @_;
-
- my %members = $main::auth->read_all_users();
- my $dbupdater = SL::DBUpgrade2->new(form => $form)->parse_dbupdate_controls;
-
- my ($query, $sth, %dbs_needing_updates);
-
- foreach my $login (grep /[a-z]/, keys %members) {
- my $member = $members{$login};
-
- map { $form->{$_} = $member->{$_} } qw(dbname dbuser dbpasswd dbhost dbport);
- dbconnect_vars($form, $form->{dbname});
-
- my $dbh = SL::DBConnect->connect($form->{dbconnect}, $form->{dbuser}, $form->{dbpasswd}, SL::DBConnect->get_options);
-
- next unless $dbh;
-
- my $version;
-
- $query = qq|SELECT version FROM defaults|;
- $sth = prepare_query($form, $dbh, $query);
- if ($sth->execute()) {
- ($version) = $sth->fetchrow_array();
- }
- $sth->finish();
-
- $dbh->disconnect and next unless $version;
-
- my $update_available = $dbupdater->update_available($version) || $dbupdater->update2_available($dbh);
- $dbh->disconnect;
-
- if ($update_available) {
- my $dbinfo = {};
- map { $dbinfo->{$_} = $member->{$_} } grep /^db/, keys %{ $member };
- $dbs_needing_updates{$member->{dbhost} . "::" . $member->{dbname}} = $dbinfo;
- }
- }
-
- $main::lxdebug->leave_sub();
-
- return values %dbs_needing_updates;
-}
-
sub calc_version {
$main::lxdebug->enter_sub(2);
sub dbupdate2 {
$main::lxdebug->enter_sub();
- my ($self, $form, $dbupdater) = @_;
+ my ($self, %params) = @_;
- my $rc = -2;
- my $db_charset = $::lx_office_conf{system}->{dbcharset} || Common::DEFAULT_CHARSET;
+ my $form = $params{form};
+ my $dbupdater = $params{updater};
+ my $db = $params{database};
+ my $rc = -2;
+ my $db_charset = $::lx_office_conf{system}->{dbcharset} || Common::DEFAULT_CHARSET;
map { $_->{description} = SL::Iconv::convert($_->{charset}, $db_charset, $_->{description}) } values %{ $dbupdater->{all_controls} };
- foreach my $db (split / /, $form->{dbupdate}) {
- next unless $form->{$db};
-
- # strip db from dataset
- $db =~ s/^db//;
- &dbconnect_vars($form, $db);
-
- my $dbh = SL::DBConnect->connect($form->{dbconnect}, $form->{dbuser}, $form->{dbpasswd}, SL::DBConnect->get_options) or $form->dberror;
+ &dbconnect_vars($form, $db);
- $dbh->do($form->{dboptions}) if ($form->{dboptions});
-
- $self->create_schema_info_table($form, $dbh);
-
- my @upgradescripts = $dbupdater->unapplied_upgrade_scripts($dbh);
-
- $dbh->disconnect and next if !@upgradescripts;
-
- foreach my $control (@upgradescripts) {
- # apply upgrade
- $main::lxdebug->message(LXDebug->DEBUG2(), "Applying Update $control->{file}");
- print $form->parse_html_template("dbupgrade/upgrade_message2", $control);
+ my $dbh = SL::DBConnect->connect($form->{dbconnect}, $form->{dbuser}, $form->{dbpasswd}, SL::DBConnect->get_options) or $form->dberror;
- $dbupdater->process_file($dbh, "sql/Pg-upgrade2/$control->{file}", $control, $db_charset);
- }
-
- $rc = 0;
- $dbh->disconnect;
-
- }
-
- $main::lxdebug->leave_sub();
-
- return $rc;
-}
+ $dbh->do($form->{dboptions}) if ($form->{dboptions});
-sub save_member {
- $main::lxdebug->enter_sub();
-
- my ($self) = @_;
-
- # format dbconnect and dboptions string
- dbconnect_vars($self, $self->{dbname});
-
- map { $self->{$_} =~ s/\r//g; } qw(address signature);
-
- $main::auth->save_user($self->{login}, map { $_, $self->{$_} } config_vars());
-
- my $dbh = SL::DBConnect->connect($self->{dbconnect}, $self->{dbuser}, $self->{dbpasswd}, SL::DBConnect->get_options);
- if ($dbh) {
- $self->create_employee_entry($::form, $dbh, $self, 1);
- $dbh->disconnect();
- }
-
- $main::lxdebug->leave_sub();
-}
-
-sub create_employee_entry {
- $main::lxdebug->enter_sub();
-
- my $self = shift;
- my $form = shift;
- my $dbh = shift;
- my $myconfig = shift;
- my $update_existing = shift;
+ $self->create_schema_info_table($form, $dbh);
- if (!does_table_exist($dbh, 'employee')) {
- $main::lxdebug->leave_sub();
- return;
- }
+ my @upgradescripts = $dbupdater->unapplied_upgrade_scripts($dbh);
- # add login to employee table if it does not exist
- # no error check for employee table, ignore if it does not exist
- my ($id) = selectrow_query($form, $dbh, qq|SELECT id FROM employee WHERE login = ?|, $self->{login});
- my ($good_db) = selectrow_query($form, $dbh, qq|select * from pg_tables where tablename = ? and schemaname = ?|, 'schema_info', 'public');
- my $can_delete;
- ($can_delete) = selectrow_query($form, $dbh, qq|SELECT tag FROM schema_info WHERE tag = ?|, 'employee_deleted') if $good_db;
+ $dbh->disconnect and next if !@upgradescripts;
- if (!$id) {
- my $query = qq|INSERT INTO employee (login, name, workphone, role) VALUES (?, ?, ?, ?)|;
- do_query($form, $dbh, $query, ($self->{login}, $myconfig->{name}, $myconfig->{tel}, "user"));
+ foreach my $control (@upgradescripts) {
+ # apply upgrade
+ $main::lxdebug->message(LXDebug->DEBUG2(), "Applying Update $control->{file}");
+ print $form->parse_html_template("dbupgrade/upgrade_message2", $control);
- } elsif ($update_existing && $can_delete) {
- my $query = qq|UPDATE employee SET name = ?, workphone = ?, role = 'user', deleted = 'f' WHERE id = ?|;
- do_query($form, $dbh, $query, $myconfig->{name}, $myconfig->{tel}, $id);
+ $dbupdater->process_file($dbh, "sql/Pg-upgrade2/$control->{file}", $control, $db_charset);
}
- $main::lxdebug->leave_sub();
-}
-
-sub config_vars {
- $main::lxdebug->enter_sub();
-
- my @conf = qw(copies countrycode dateformat default_media default_printer_id email favorites fax hide_cvar_search_options mandatory_departments menustyle name
- numberformat show_form_details signature stylesheet taxincluded_checked tel template_format vclimit);
+ $rc = 0;
+ $dbh->disconnect;
$main::lxdebug->leave_sub();
- return @conf;
+ return $rc;
}
sub data {