From 68d46d3841e7306f2aeb4e3e19d88b7e8f712053 Mon Sep 17 00:00:00 2001 From: Moritz Bunkus Date: Fri, 18 May 2007 15:25:08 +0000 Subject: [PATCH] =?utf8?q?Funktionen=20hinzugef=C3=BCgt,=20mit=20denen=20m?= =?utf8?q?an=20ein=20Datenbankbackup=20mit=20Hilfe=20von=20"pg=5Frestore"?= =?utf8?q?=20wieder=20einspielen=20kann.=20Dabei=20muss=20das=20Backup=20m?= =?utf8?q?it=20"pg=5Fdump=20-Ft"=20erzegut=20worden=20sein,=20so=20wie=20e?= =?utf8?q?s=20die=20eigene=20Backup-Funktion=20auch=20tut.?= MIME-Version: 1.0 Content-Type: text/plain; charset=utf8 Content-Transfer-Encoding: 8bit --- bin/mozilla/admin.pl | 168 ++++++++++++++++-- locale/de/admin | 3 + locale/de/all | 13 ++ lx-erp.conf | 10 +- templates/webpages/admin/dbadmin_de.html | 2 +- templates/webpages/admin/dbadmin_master.html | 2 +- .../webpages/admin/restore_dataset_de.html | 57 ++++++ .../admin/restore_dataset_master.html | 57 ++++++ .../restore_dataset_start_footer_de.html | 15 ++ .../restore_dataset_start_footer_master.html | 15 ++ .../restore_dataset_start_header_de.html | 9 + .../restore_dataset_start_header_master.html | 9 + 12 files changed, 339 insertions(+), 21 deletions(-) create mode 100644 templates/webpages/admin/restore_dataset_de.html create mode 100644 templates/webpages/admin/restore_dataset_master.html create mode 100644 templates/webpages/admin/restore_dataset_start_footer_de.html create mode 100644 templates/webpages/admin/restore_dataset_start_footer_master.html create mode 100644 templates/webpages/admin/restore_dataset_start_header_de.html create mode 100644 templates/webpages/admin/restore_dataset_start_header_master.html diff --git a/bin/mozilla/admin.pl b/bin/mozilla/admin.pl index 9805417cd..edbb35cc4 100644 --- a/bin/mozilla/admin.pl +++ b/bin/mozilla/admin.pl @@ -48,6 +48,7 @@ use SL::User; use SL::Common; use SL::Inifile; use SL::DBUpgrade2; +use SL::DBUtils; require "bin/mozilla/common.pl"; @@ -90,7 +91,7 @@ if ($form->{action}) { # create memberfile if (!-f $memberfile) { - open(FH, ">$memberfile") or $form->error("$memberfile : $!"); + open(FH, ">$memberfile") or $form->error("$memberfile : $ERRNO"); print FH qq|# SQL-Ledger Accounting members [root login] @@ -125,7 +126,7 @@ sub list_users { $form->error($locale->text('File locked!')) if (-f "${memberfile}.LCK"); - open(FH, "$memberfile") or $form->error("$memberfile : $!"); + open(FH, "$memberfile") or $form->error("$memberfile : $ERRNO"); my %members; @@ -220,7 +221,7 @@ sub edit_user_form { $form->error(sprintf($locale->text("The directory %s does not exist."), $templates)); } - opendir TEMPLATEDIR, "$templates/." or $form->error("$templates : $!"); + opendir TEMPLATEDIR, "$templates/." or $form->error("$templates : $ERRNO"); my @all = readdir(TEMPLATEDIR); my @alldir = sort grep { -d "$templates/$_" && !/^\.\.?$/ } @all; my @allhtml = sort grep { -f "$templates/$_" && /\.html$/ } @all; @@ -258,7 +259,7 @@ sub edit_user_form { my @acsorder = (); my %acs = (); my %excl = (); - open(FH, $menufile) or $form->error("$menufile : $!"); + open(FH, $menufile) or $form->error("$menufile : $ERRNO"); while ($item = ) { next unless $item =~ /\[/; @@ -393,7 +394,7 @@ sub save { } close(HTACCESS); } - open(HTACCESS, "> $file") or die "cannot open $file $!\n"; + open(HTACCESS, "> $file") or die "cannot open $file $ERRNO\n"; $newfile .= $myconfig->{login} . ":" . $myconfig->{password} . "\n"; print(HTACCESS $newfile); close(HTACCESS); @@ -408,7 +409,7 @@ sub save { } close(HTACCESS); } - open(HTACCESS, "> $file") or die "cannot open $file $!\n"; + open(HTACCESS, "> $file") or die "cannot open $file $ERRNO\n"; print(HTACCESS $newfile); close(HTACCESS); } @@ -428,18 +429,18 @@ sub save { umask(007); # copy templates to the directory - opendir TEMPLATEDIR, "$templates/." or $form - error("$templates : $!"); + opendir TEMPLATEDIR, "$templates/." or $form - error("$templates : $ERRNO"); @templates = grep /$form->{mastertemplates}.*?\.(html|tex|sty|xml|txb)$/, readdir TEMPLATEDIR; closedir TEMPLATEDIR; foreach $file (@templates) { open(TEMP, "$templates/$file") - or $form->error("$templates/$file : $!"); + or $form->error("$templates/$file : $ERRNO"); $file =~ s/$form->{mastertemplates}-//; open(NEW, ">$form->{templates}/$file") - or $form->error("$form->{templates}/$file : $!"); + or $form->error("$form->{templates}/$file : $ERRNO"); while ($line = ) { print NEW $line; @@ -448,7 +449,7 @@ sub save { close(NEW); } } else { - $form->error("$!: $form->{templates}"); + $form->error("$ERRNO: $form->{templates}"); } } @@ -458,7 +459,7 @@ sub save { sub delete { $form->error($locale->text('File locked!')) if (-f ${memberfile} . LCK); - open(FH, ">${memberfile}.LCK") or $form->error("${memberfile}.LCK : $!"); + open(FH, ">${memberfile}.LCK") or $form->error("${memberfile}.LCK : $ERRNO"); close(FH); my $members = Inifile->new($memberfile); @@ -632,7 +633,7 @@ sub create_dataset { $form->{CHARTS} = []; - opendir SQLDIR, "sql/." or $form - error($!); + opendir SQLDIR, "sql/." or $form - error($ERRNO); foreach $item (sort grep /-chart\.sql\z/, readdir SQLDIR) { next if ($item eq 'Default-chart.sql'); $item =~ s/-chart\.sql//; @@ -743,13 +744,13 @@ sub backup_dataset_start { $form->isblank("to", $locale->text('The email address is missing.')) if $form->{destination} eq "email"; my $tmpdir = "/tmp/lx_office_backup_" . Common->unique_id(); - mkdir $tmpdir, 0700 || $form->error($locale->text('A temporary directory could not be created:') . " $!"); + mkdir $tmpdir, 0700 || $form->error($locale->text('A temporary directory could not be created:') . " $ERRNO"); my $pgpass = IO::File->new("${tmpdir}/.pgpass", O_WRONLY | O_CREAT, 0600); if (!$pgpass) { unlink $tmpdir; - $form->error($locale->text('A temporary file could not be created:') . " $!"); + $form->error($locale->text('A temporary file could not be created:') . " $ERRNO"); } print $pgpass "$form->{dbhost}:$form->{dbport}:$form->{dbname}:$form->{dbuser}:$form->{dbpasswd}\n"; @@ -823,9 +824,146 @@ sub restore_dataset { . $locale->text('Database Administration') . " / " . $locale->text('Restore Dataset'); - if ("$pg_dump_exe" eq "DISABLED") { + if ("$pg_restore_exe" eq "DISABLED") { $form->error($locale->text('Database backups and restorations are disabled in lx-erp.conf.')); } + + my $default_charset = $dbcharset; + $default_charset ||= Common::DEFAULT_CHARSET; + + $form->{DBENCODINGS} = []; + + foreach my $encoding (@Common::db_encodings) { + push @{ $form->{DBENCODINGS} }, { "dbencoding" => $encoding->{dbencoding}, + "label" => $encoding->{label}, + "selected" => $encoding->{charset} eq $default_charset }; + } + + $form->header(); + print $form->parse_html_template("admin/restore_dataset"); +} + +sub restore_dataset_start { + $form->{title} = + "Lx-Office ERP " + . $locale->text('Database Administration') . " / " + . $locale->text('Restore Dataset'); + + $pg_restore_exe ||= "pg_restore"; + + if ("$pg_restore_exe" eq "DISABLED") { + $form->error($locale->text('Database backups and restorations are disabled in lx-erp.conf.')); + } + + $form->isblank("new_dbname", $locale->text('The dataset name is missing.')); + $form->isblank("content", $locale->text('No backup file has been uploaded.')); + + # Create temporary directories. Write the backup file contents to a temporary + # file. Create a .pgpass file with the username and password for the pg_restore + # utility. + + my $tmpdir = "/tmp/lx_office_backup_" . Common->unique_id(); + mkdir $tmpdir, 0700 || $form->error($locale->text('A temporary directory could not be created:') . " $ERRNO"); + + my $pgpass = IO::File->new("${tmpdir}/.pgpass", O_WRONLY | O_CREAT, 0600); + + if (!$pgpass) { + unlink $tmpdir; + $form->error($locale->text('A temporary file could not be created:') . " $ERRNO"); + } + + print $pgpass "$form->{dbhost}:$form->{dbport}:$form->{new_dbname}:$form->{dbuser}:$form->{dbpasswd}\n"; + $pgpass->close(); + + $ENV{HOME} = $tmpdir; + + my $tmp = $tmpdir . "/dump_" . Common::unique_id(); + my $tmpfile; + + if (substr($form->{content}, 0, 2) eq "\037\213") { + $tmpfile = IO::File->new("| gzip -d > $tmp"); + $tmpfile->binary(); + + } else { + $tmpfile = IO::File->new($tmp, O_WRONLY | O_CREAT | O_BINARY, 0600); + } + + if (!$tmpfile) { + unlink "${tmpdir}/.pgpass"; + rmdir $tmpdir; + + $form->error($locale->text('A temporary file could not be created:') . " $ERRNO"); + } + + print $tmpfile $form->{content}; + $tmpfile->close(); + + delete $form->{content}; + + # Try to connect to the database. Find out if a database with the same name exists. + # If yes, then drop the existing database. Create a new one with the name and encoding + # given by the user. + + User::dbconnect_vars($form, "template1"); + + my %myconfig = map { $_ => $form->{$_} } grep /^db/, keys %{ $form }; + my $dbh = $form->dbconnect(\%myconfig) || $form->dberror(); + + my ($query, $sth); + + $form->{new_dbname} =~ s|[^a-zA-Z0-9_\-]||g; + + $query = qq|SELECT COUNT(*) FROM pg_database WHERE datname = ?|; + my ($count) = selectrow_query($form, $dbh, $query, $form->{new_dbname}); + if ($count) { + do_query($form, $dbh, qq|DROP DATABASE $form->{new_dbname}|); + } + + my $found = 0; + foreach my $item (@Common::db_encodings) { + if ($item->{dbencoding} eq $form->{dbencoding}) { + $found = 1; + last; + } + } + $form->{dbencoding} = "LATIN9" unless $form->{dbencoding}; + + do_query($form, $dbh, qq|CREATE DATABASE $form->{new_dbname} ENCODING ? TEMPLATE template0|, $form->{dbencoding}); + + $dbh->disconnect(); + + # Spawn pg_restore on the temporary file. + + my @args = ("-h", $form->{dbhost}, "-U", $form->{dbuser}, "-d", $form->{new_dbname}); + push @args, ("-p", $form->{dbport}) if ($form->{dbport}); + push @args, $tmp; + + my $cmd = "${pg_restore_exe} " . join(" ", map { s/\\/\\\\/g; s/\"/\\\"/g; $_ } @args); + + my $in = IO::File->new("$cmd 2>&1 |"); + + if (!$in) { + unlink "${tmpdir}/.pgpass", $tmp; + rmdir $tmpdir; + + $form->error($locale->text('The pg_restore process could not be started.')); + } + + $AUTOFLUSH = 1; + + $form->header(); + print $form->parse_html_template("admin/restore_dataset_start_header"); + + while (my $line = <$in>) { + print $line; + } + $in->close(); + + $form->{retval} = $CHILD_ERROR >> 8; + print $form->parse_html_template("admin/restore_dataset_start_footer"); + + unlink "${tmpdir}/.pgpass", $tmp; + rmdir $tmpdir; } sub unlock_system { diff --git a/locale/de/admin b/locale/de/admin index c428864f8..81b8aac60 100644 --- a/locale/de/admin +++ b/locale/de/admin @@ -45,6 +45,7 @@ $self->{texts} = { 'No Database Drivers available!' => 'Kein Datenbanktreiber verfügbar!', 'No Dataset selected!' => 'Keine Datenbank ausgewählt!', 'No Vendor was found matching the search parameters.' => 'Zu dem Suchbegriff wurde kein Händler gefunden', + 'No backup file has been uploaded.' => 'Es wurde keine Sicherungsdatei hochgeladen.', 'No customer has been selected yet.' => 'Es wurde noch kein Kunde ausgewählt.', 'No employee was found matching the search parameters.' => 'Es wurde kein Angestellter gefunden, auf den die Suchparameter zutreffen.', 'No part was found matching the search parameters.' => 'Es wurde kein Artikel gefunden, auf den die Suchparameter zutreffen.', @@ -84,6 +85,7 @@ $self->{texts} = { 'The login is missing.' => 'Das Login fehlt.', 'The passwords do not match.' => 'Die Passwörter stimmen nicht überein.', 'The pg_dump process could not be started.' => 'Der pg_dump-Prozess konnte nicht gestartet werden.', + 'The pg_restore process could not be started.' => 'Der pg_restore-Prozess konnte nicht gestartet werden.', 'Trying to call a sub without a name' => 'Es wurde versucht, eine Unterfunktion ohne Namen aufzurufen.', 'Unit' => 'Einheit', 'Unknown dependency \'%s\'.' => 'Unbekannte Abhängigkeit \'%s\'.', @@ -143,6 +145,7 @@ $self->{subs} = { 'project_selection_internal' => 'project_selection_internal', 'reformat_numbers' => 'reformat_numbers', 'restore_dataset' => 'restore_dataset', + 'restore_dataset_start' => 'restore_dataset_start', 'restore_form' => 'restore_form', 'save' => 'save', 'save_form' => 'save_form', diff --git a/locale/de/all b/locale/de/all index 5b29a808e..a8cc8e465 100644 --- a/locale/de/all +++ b/locale/de/all @@ -169,6 +169,7 @@ aktualisieren wollen?', 'BWA' => 'BWA', 'Back' => 'Zurück', 'Backup Dataset' => 'Datenbank sichern', + 'Backup file' => 'Sicherungsdatei', 'Backup of dataset' => 'Sicherung der Datenbank', 'Balance' => 'Bilanz', 'Balance Sheet' => 'Bilanz', @@ -329,6 +330,7 @@ aktualisieren wollen?', 'Database update error:' => 'Fehler beim Datenbankupgrade:', 'Dataset' => 'Datenbank', 'Dataset missing!' => 'Datenbank fehlt!', + 'Dataset name' => 'Datenbankname', 'Dataset upgrade' => 'Datenbankaktualisierung', 'Date' => 'Datum', 'Date Format' => 'Datumsformat', @@ -489,6 +491,7 @@ gestartet', 'February' => 'Februar', 'Fee' => 'Gebühr', 'File locked!' => 'Datei gesperrt!', + 'Files created by Lx-Office\'s "Backup Dataset" function are such files.' => 'Dateien, die von Lx-Office\' Funktion "Datenbank sichern" erstellt wurden, erfüllen diese Kriterien.', 'Folgekonto' => 'Folgekonto', 'For each unit there\'s either no or exactly one base unit. If you chose a base unit then you also have to chose a factor. That way the new unit will be defined as a multiple of the base unit. The base unit must be the "smaller" one. A factor may not be less than 1. Therefore you may define "kg" with the base unit "g" and a factor of "1", but not the other way round.' => 'Einheiten haben entweder keine oder genau eine Basiseinheit, von der sie ein Vielfaches sind. Wenn Sie eine Basiseinheit auswählen, dann müssen Sie auch einen Faktor eingeben. Sie müssen Einheiten als ein Vielfaches einer kleineren Einheit eingeben. So ist die Definition von "kg" mit der Basiseinheit "g" und dem Faktor 1000 zulässig, die Definition von "g" mit der Basiseinheit "kg" und dem Faktor "0,001" hingegen nicht.', 'Foreign Exchange Gain' => 'Wechselkurserträge', @@ -581,6 +584,7 @@ gestartet', 'Is this a summary account to record' => 'Buchungskonto in', '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 may optionally be compressed with "gzip".' => 'Sie darf optional mit "gzip" komprimiert sein.', 'Item deleted!' => 'Artikel gelöscht!', 'Item not on file!' => 'Dieser Artikel ist nicht in der Datenbank!', 'Jan' => 'Jan', @@ -704,6 +708,7 @@ gestartet', 'No Database Drivers available!' => 'Kein Datenbanktreiber verfügbar!', 'No Dataset selected!' => 'Keine Datenbank ausgewählt!', 'No Vendor was found matching the search parameters.' => 'Zu dem Suchbegriff wurde kein Händler gefunden', + 'No backup file has been uploaded.' => 'Es wurde keine Sicherungsdatei hochgeladen.', 'No customer has been selected yet.' => 'Es wurde noch kein Kunde ausgewählt.', 'No databases have been found on this server.' => 'Auf diesem Server wurden keine Datenbanken gefunden.', 'No datasets have been selected.' => 'Es wurden keine Datenbanken ausgewählt.', @@ -801,6 +806,7 @@ gestartet', 'Pick List' => 'Sammelliste', 'Please enter a license key.' => 'Bitte geben Sie einen Lizenzschlüssel an.', 'Please enter a number of licenses.' => 'Bitte geben Sie die Anzahl Lizenzschlüssel an.', + 'Please enter the name of the dataset you want to restore the backup in.' => 'Bitte geben Sie den Namen der Datenbank ein, in der Sie die Sicherung wiederherstellen wollen.', 'Please enter values' => 'Bitte Werte eingeben', 'Please insert object dimensions below.' => 'Bitte geben Sie die Abmessungen unten ein', 'Please insert your language values below' => 'Bitte die Übersetzungen unten eintragen', @@ -1041,6 +1047,7 @@ gestartet', 'Templates' => 'Vorlagen', 'Terms missing in row ' => '+Tage fehlen in Zeile ', 'The \'tag\' field must only consist of alphanumeric characters or the carachters - _ ( )' => 'Das Feld \'tag\' darf nur aus alphanumerischen Zeichen und den Zeichen - _ ( ) bestehen.', + 'The backup you upload here has to be a file created with "pg_dump -o -Ft".' => 'Die von Ihnen hochzuladende Sicherungsdatei muss mit dem Programm und den Parametern "pg_dump -o -Ft" erstellt worden sein.', 'The base unit does not exist or it is about to be deleted in row %d.' => 'Die Basiseinheit in Zeile %d existiert nicht oder soll gelöscht werden.', 'The base unit does not exist.' => 'Die Basiseinheit existiert nicht.', 'The base unit relations must not contain loops (e.g. by saying that unit A\'s base unit is B, B\'s base unit is C and C\'s base unit is A) in row %d.' => 'Die Beziehungen der Einheiten dürfen keine Schleifen beinhalten (z.B. wenn gesagt wird, dass Einheit As Basiseinheit B, Bs Basiseinheit C und Cs Basiseinheit A ist) in Zeile %d.', @@ -1050,6 +1057,7 @@ gestartet', 'The database upgrade for the introduction of units is now complete.' => 'Das Datenbankupgrade zwecks Einführung von Einheiten ist nun beendet.', 'The dataset has been successfully created.' => 'Die Datenbank wurde erfolgreich erstellt.', 'The dataset backup has been sent via email to .' => 'Die Datenbanksicherung wurde an per Email verschickt.', + 'The dataset has to exist before a restoration can be started.' => 'Die Datenbank muss vor der Wiederherstellung bereits angelegt worden sein.', 'The dataset name is missing.' => 'Der Datenbankname fehlt.', 'The directory %s does not exist.' => 'Das Verzeichnis %s existiert nicht.', 'The dunning process started' => 'Der Mahnprozess ist gestartet.', @@ -1070,7 +1078,11 @@ gestartet', 'The name is missing.' => 'Der Name fehlt.', 'The passwords do not match.' => 'Die Passwörter stimmen nicht überein.', 'The pg_dump process could not be started.' => 'Der pg_dump-Prozess konnte nicht gestartet werden.', + 'The pg_restore process could not be started.' => 'Der pg_restore-Prozess konnte nicht gestartet werden.', 'The preferred one is to install packages provided by your operating system distribution (e.g. Debian or RPM packages).' => 'Die bevorzugte Art, ein Perl-Modul zu installieren, ist durch Installation eines von Ihrem Betriebssystem zur Verfügung gestellten Paketes (z.B. Debian-Pakete oder RPM).', + 'The program\'s exit code was ("0" usually means that everything went OK).' => 'Der Exitcode des Programms war ("0" bedeutet normalerweise, dass die Wiederherstellung erfolgreich war).', + 'The restoration process has started. Here\'s the output of the "pg_restore" command:' => 'Der Wiederherstellungsprozess wurde gestartet. Hier ist die Ausgabe des "pg_restore"-Programmes:', + 'The restoration process is complete. Please review "pg_restore"\'s output to find out if the restoration was successful.' => 'Die Wiederherstellung ist abgeschlossen. Bitte sehen Sie sich die Ausgabe von "pg_restore" an, um festzustellen, ob die Wiederherstellung erfolgreich war.', 'The second way is to use Perl\'s CPAN module and let it download and install the module for you.' => 'Die zweite Variante besteht darin, Perls CPAN-Modul zu benutzen und es das Modul für Sie installieren zu lassen.', 'The third way is to download the module from the above mentioned URL and to install the module manually following the installations instructions contained in the source archive.' => 'Die dritte Variante besteht darin, das Paket von der oben genannten URL herunterzuladen und es manuell zu installieren. Beachten Sie dabei die im Paket enthaltenen Installationsanweisungen.', 'The unit has been saved.' => 'Die Einheit wurde gespeichert.', @@ -1187,6 +1199,7 @@ gestartet', 'Yes' => 'Ja', 'You are logged out!' => 'Auf Wiedersehen!', 'You can also create new units now.' => 'Sie können jetzt auch neue Einheiten anlegen.', + 'You can create a missing dataset by going back and chosing "Create Dataset".' => 'Sie können eine fehlende Datenbank erstellen, indem Sie jetzt zuück gehen und den Punkt "Datenbank anlegen" wählen.', 'You can only delete datasets that are not in use.' => 'Sie können nur Datenbanken löschen, die momentan nicht in Benutzung sind.', 'You can use the following strings in the long description and all translations. They will be replaced by their actual values by Lx-Office before they\'re output.' => 'Sie können im Langtext und allen Übersetzungen die folgenden Variablen benutzen, die vor der Ausgabe von Lx-Office automatisch ersetzt werden:', 'You cannot continue before all required modules are installed.' => 'Sie können nicht fortfahren, bevor alle benötigten Pakete installiert sind.', diff --git a/lx-erp.conf b/lx-erp.conf index 190eea7e2..9b4413e1e 100644 --- a/lx-erp.conf +++ b/lx-erp.conf @@ -1,5 +1,5 @@ use Cwd; -use vars qw($userspath $spool $memberfile $templates $sendmail $language $sid $latex $eur $webdav $lizenzen $pg_dump_exe $watch_form_variables); +use vars qw($userspath $spool $memberfile $templates $sendmail $language $sid $latex $eur $webdav $lizenzen $pg_dump_exe $pg_restore_exe $watch_form_variables); # path to user configuration files $userspath = "users"; @@ -70,9 +70,11 @@ $dbcharset = "ISO-8859-15"; # Datenbankbackups werden mit dem externen Programm "pg_dump" erledigt. # Wenn es nicht im aktuellen Pfad vorhanden ist, so muss hier der vollständige # Pfad eingetragen werden. Wenn die Variable auf "DISABLED" gesetzt wird, -# so werden die Menüpunkte zum Backup und Wiederherstellen von Datenbanken -# im Administrationsfrontend nicht angeboten. -$pg_dump_exe = "pg_dump"; +# so wird der Menüpunkt zum Backup von Datenbanken im Administrationsfrontend +# nicht angeboten. +# Das gleiche gilt analog für das Wiederherstellen mittels "pg_restore". +$pg_dump_exe = "pg_dump"; +$pg_restore_exe = "pg_restore"; # Globale Debug-Ausgaben (de-)aktivieren? Moegliche Werte sind # LXDebug::NONE - keine Debugausgaben diff --git a/templates/webpages/admin/dbadmin_de.html b/templates/webpages/admin/dbadmin_de.html index a2bf40a11..615c74e46 100644 --- a/templates/webpages/admin/dbadmin_de.html +++ b/templates/webpages/admin/dbadmin_de.html @@ -57,7 +57,7 @@ - + diff --git a/templates/webpages/admin/dbadmin_master.html b/templates/webpages/admin/dbadmin_master.html index 2be64a579..2123f807e 100644 --- a/templates/webpages/admin/dbadmin_master.html +++ b/templates/webpages/admin/dbadmin_master.html @@ -57,7 +57,7 @@ - + diff --git a/templates/webpages/admin/restore_dataset_de.html b/templates/webpages/admin/restore_dataset_de.html new file mode 100644 index 000000000..0575cabf2 --- /dev/null +++ b/templates/webpages/admin/restore_dataset_de.html @@ -0,0 +1,57 @@ + + +

+ +
+ + + + + + +

+ Bitte geben Sie den Namen der Datenbank ein, in der Sie die Sicherung wiederherstellen wollen. + Die Datenbank muss vor der Wiederherstellung bereits angelegt worden sein. + Sie können eine fehlende Datenbank erstellen, indem Sie jetzt zuück gehen und den Punkt "Datenbank anlegen" wählen. +

+ +

+ Die von Ihnen hochzuladende Sicherungsdatei muss mit dem Programm und den Parametern "pg_dump -o -Ft" erstellt worden sein. + Sie darf optional mit "gzip" komprimiert sein. + Dateien, die von Lx-Office' Funktion "Datenbank sichern" erstellt wurden, erfüllen diese Kriterien. +

+ + + + + + + + + + + + + + + + +
Datenbankname
Schriftsatz + +
Sicherungsdatei
+ + + + +
+ +
+ + + +
+ + + diff --git a/templates/webpages/admin/restore_dataset_master.html b/templates/webpages/admin/restore_dataset_master.html new file mode 100644 index 000000000..c521fc925 --- /dev/null +++ b/templates/webpages/admin/restore_dataset_master.html @@ -0,0 +1,57 @@ + + +

+ +
+ + + + + + +

+ Please enter the name of the dataset you want to restore the backup in. + The dataset has to exist before a restoration can be started. + You can create a missing dataset by going back and chosing "Create Dataset". +

+ +

+ The backup you upload here has to be a file created with "pg_dump -o -Ft". + It may optionally be compressed with "gzip". + Files created by Lx-Office's "Backup Dataset" function are such files. +

+ + + + + + + + + + + + + + + + +
Dataset name
Multibyte Encoding + +
Backup file
+ + + + +
+ +
+ + + +
+ + + diff --git a/templates/webpages/admin/restore_dataset_start_footer_de.html b/templates/webpages/admin/restore_dataset_start_footer_de.html new file mode 100644 index 000000000..926673099 --- /dev/null +++ b/templates/webpages/admin/restore_dataset_start_footer_de.html @@ -0,0 +1,15 @@ + + +
+ +

+ Die Wiederherstellung ist abgeschlossen. Bitte sehen Sie sich die Ausgabe von "pg_restore" an, um festzustellen, ob die Wiederherstellung erfolgreich war. + Der Exitcode des Programms war ("0" bedeutet normalerweise, dass die Wiederherstellung erfolgreich war). +

+ +
+ + +
+ + diff --git a/templates/webpages/admin/restore_dataset_start_footer_master.html b/templates/webpages/admin/restore_dataset_start_footer_master.html new file mode 100644 index 000000000..a105e2140 --- /dev/null +++ b/templates/webpages/admin/restore_dataset_start_footer_master.html @@ -0,0 +1,15 @@ + + +
+ +

+ The restoration process is complete. Please review "pg_restore"'s output to find out if the restoration was successful. + The program's exit code was ("0" usually means that everything went OK). +

+ +
+ + +
+ + diff --git a/templates/webpages/admin/restore_dataset_start_header_de.html b/templates/webpages/admin/restore_dataset_start_header_de.html new file mode 100644 index 000000000..b575d1281 --- /dev/null +++ b/templates/webpages/admin/restore_dataset_start_header_de.html @@ -0,0 +1,9 @@ + + +

+ +

Der Wiederherstellungsprozess wurde gestartet. Hier ist die Ausgabe des "pg_restore"-Programmes:

+ +
+ +
diff --git a/templates/webpages/admin/restore_dataset_start_header_master.html b/templates/webpages/admin/restore_dataset_start_header_master.html
new file mode 100644
index 000000000..b047125a9
--- /dev/null
+++ b/templates/webpages/admin/restore_dataset_start_header_master.html
@@ -0,0 +1,9 @@
+
+
+ 

+ +

The restoration process has started. Here's the output of the "pg_restore" command:

+ +
+ +
-- 
2.20.1