From mboxrd@z Thu Jan 1 00:00:00 1970 From: Matthias Fischer To: development@lists.ipfire.org Subject: [PATCH] backup.cgi: Table layout - onclick confirm Date: Wed, 26 May 2021 17:39:37 +0200 Message-ID: <20210526153937.2720-1-matthias.fischer@ipfire.org> MIME-Version: 1.0 Content-Type: multipart/mixed; boundary="===============6975769050322198388==" List-Id: --===============6975769050322198388== Content-Type: text/plain; charset="utf-8" Content-Transfer-Encoding: quoted-printable This is just a diff for testing people... ;-) Changelog in short: - Added tables - Cleaned up the code a bit, some if-queries were unnessecary (if ($cgiparams{'ACTION'} eq...) - Deleted unused lang strings (downloadiso, downloadaddon, logs) - Separated the ISO files from the IPF files for better overview. - Added query for deleting a backup file (onclick=3D\"return confirm...) ToDo: Change table layout to alternating rows. If "someone" has some hints how to do this, I'll be grateful. Signed-off-by: Matthias Fischer --- html/cgi-bin/backup.cgi | 218 +++++++++++++++++++++++++++++----------- langs/de/cgi-bin/de.pl | 8 +- langs/en/cgi-bin/en.pl | 8 +- langs/es/cgi-bin/es.pl | 1 - langs/fr/cgi-bin/fr.pl | 1 - langs/it/cgi-bin/it.pl | 1 - langs/nl/cgi-bin/nl.pl | 1 - langs/pl/cgi-bin/pl.pl | 1 - langs/ru/cgi-bin/ru.pl | 1 - langs/tr/cgi-bin/tr.pl | 1 - 10 files changed, 174 insertions(+), 67 deletions(-) diff --git a/html/cgi-bin/backup.cgi b/html/cgi-bin/backup.cgi index 683f8add4..04473428c 100644 --- a/html/cgi-bin/backup.cgi +++ b/html/cgi-bin/backup.cgi @@ -32,7 +32,7 @@ require "${General::swroot}/header.pl"; =20 my %color =3D (); my %mainsettings =3D (); -my %cgiparams=3D(); +my %cgiparams =3D (); my %checked =3D (); my $message =3D ""; my $errormessage =3D ""; @@ -59,25 +59,13 @@ system("/usr/local/bin/backupctrl makedirs >/dev/null 2>&= 1 ") unless ( -e '/var/ ############################################################################= ################################################ ############################################## System calls ohne Http Header= ############################################### =20 -if ($cgiparams{'ACTION'} eq "download") { +if ($cgiparams{'ACTION'} eq "$Lang::tr{'download'}") { my $file =3D &sanitise_file($cgiparams{'FILE'}); exit(1) unless defined($file); =20 &deliver_file($file); exit(0); -} elsif ($cgiparams{'ACTION'} eq "downloadiso") { - my $file =3D &sanitise_file($cgiparams{'FILE'}); - exit(1) unless defined($file); - - &deliver_file($file); - exit(0); -} elsif ($cgiparams{'ACTION'} eq "downloadaddon") { - my $file =3D &sanitise_file($cgiparams{'FILE'}); - exit(1) unless defined($file); - - &deliver_file($file); - exit(0); -} elsif ( $cgiparams{'ACTION'} eq "restore") { +} elsif ( $cgiparams{'ACTION'} eq "$Lang::tr{'restore'}") { my $upload =3D $a->param("UPLOAD"); open UPLOADFILE, ">/tmp/restore.ipf"; binmode $upload; @@ -87,7 +75,7 @@ if ($cgiparams{'ACTION'} eq "download") { close UPLOADFILE; system("/usr/local/bin/backupctrl restore >/dev/null 2>&1"); } -elsif ( $cgiparams{'ACTION'} eq "restoreaddon" ) +elsif ( $cgiparams{'ACTION'} eq "$Lang::tr{'restoreaddon'}" ) { chomp($cgiparams{'UPLOAD'}); # we need to fix cause IE7 gives the full path and FF only the filename @@ -112,7 +100,7 @@ sub refreshpage{&Header::openbox( 'Waiting', 1, "/dev/null 2>&1"); @@ -122,7 +110,7 @@ if ( $cgiparams{'ACTION'} eq "backup" ) system("/usr/local/bin/backupctrl iso >/dev/null 2>&1"); } } -if ( $cgiparams{'ACTION'} eq "addonbackup" ) +if ( $cgiparams{'ACTION'} eq "$Lang::tr{'addonbackup'}" ) { # Exit if there is any dots or slashes in the addon name exit(1) if ($cgiparams{'ADDON'} =3D~ /(\.|\/)/); @@ -132,7 +120,7 @@ if ( $cgiparams{'ACTION'} eq "addonbackup" ) =20 system("/usr/local/bin/backupctrl addonbackup $cgiparams{'ADDON'} >/dev/nul= l 2>&1"); } -elsif ( $cgiparams{'ACTION'} eq "delete" ) +elsif ( $cgiparams{'ACTION'} eq "$Lang::tr{'delete'}" ) { my $file =3D &sanitise_file($cgiparams{'FILE'}); exit(1) unless defined($file); @@ -157,13 +145,13 @@ if ( -e "/var/tmp/backupiso/" ){ @backupisos =3D `cd /var/tmp/backupiso/ && ls *.iso 2>/dev/null`; } =20 -&Header::openbox('100%', 'center', ); +&Header::openbox('100%', 'center', $Lang::tr{'backup config'}); =20 print < - +
$Lang::tr{'logs'} $Lang::tr{'i= nclude logfiles'}
$Lang::tr{'exclude logfiles'}
@@ -177,8 +165,8 @@ print <
- - + +
@@ -189,10 +177,17 @@ END ############################################################################= ################################################ ############################################ Backups des Systems downloaden = ################################################ =20 -&Header::openbox('100%', 'center', $Lang::tr{'backups'}); +&Header::openbox('100%', 'center', $Lang::tr{'backups data'}); =20 print < + + + + + + + + END ; foreach (@backups){ @@ -202,9 +197,44 @@ my $Datei =3D "/var/ipfire/backup/".$_; my @Info =3D stat($Datei); my $Size =3D $Info[7] / 1024 / 1024; $Size =3D sprintf("%0.2f", $Size); -print ""; -print ""; + +print " + + +"; + +print ""; } + +print < +END +; +&Header::closebox(); + +&Header::openbox('100%', 'center', $Lang::tr{'backups iso'}); + +print < + + + + + + + +END +; + foreach (@backupisos){ if ( $_ !~ /iso$/){next;} chomp($_); @@ -212,8 +242,22 @@ my $Datei =3D "/var/tmp/backupiso/".$_; my @Info =3D stat($Datei); my $Size =3D $Info[7] / 1024 / 1024; $Size =3D sprintf("%0.2f", $Size); -print ""; -print ""; + +print " + + +"; + +print ""; } print < @@ -235,7 +279,19 @@ foreach (@addons){ $addons{$addon}=3D''; } =20 -print "
$Lang::tr{'filename'}$Lang::tr{'size'}$Lang::tr{'action'}
$Lang::tr{'backup from'} $_ $Lang::tr{'size'= } $Size MB
=
<= /td>
$_$Size MB
+ + + +
+
+ + + +
$Lang::tr{'filename'}$Lang::tr{'size'}$Lang::tr{'action'}
$Lang::tr{'backup from'} $_ $Lang::tr{'size'= } $Size MB
=
<= /td>
$_$Size MB
+ + + +
+
+ + + +
"; +print < + + + + + + + +END +; + foreach (@addonincluds){ chomp($_); delete $addons{$_}; @@ -245,69 +301,93 @@ my $Size =3D $Info[7] / 1024; =20 if ( -e $Datei ){ if ($Size < 1) { - $Size =3D sprintf("%.2f", $Size); - print ""; - } else { - $Size =3D sprintf("%2d", $Size); - print ""; + $Size =3D sprintf("%.2f", $Size); +print " + + + "; + =20 - } + } else { + $Size =3D sprintf("%2d", $Size); +print " + + + "; + + } =20 print < + + - END ; } -else{ - print ""; + +else { + + print " + + + + "; } + print <
- + - + -
+ + END ; + } + foreach (keys(%addons)){ chomp($_); my $Datei =3D "/var/ipfire/backup/addons/backup/".$_.".ipf"; my @Info =3D stat($Datei); my $Size =3D $Info[7] / 1024; $Size =3D sprintf("%2d", $Size); -print ""; + +print " + + + "; + print < + - - + END ; } @@ -322,9 +402,31 @@ print "
$Lang::tr{'name'}$Lang::tr{'date'}$Lang::tr{'size'}$Lang::tr{'action'}
$Lang::tr{'backup from'} $_ $Lang::tr{'si= ze'} $Size KB $Lang::tr{'date'} ".localtime($Info[9])."
$Lang::tr{'backup from'} $_ $Lang::tr{'si= ze'} $Size KB $Lang::tr{'date'} ".localtime($Info[9])."
$_".localtime($Info[9])."$Size KB
$_".localtime($Info[9])."$Size KB
- + - +
+
- + - +
$Lang::tr{'backup from'} $_
$_ - - -
$Lang::tr{'backup from'} $_ $Lang::tr{'size'= } $Size KB $Lang::tr{'date'} ".localtime($Info[9])."
$_".localtime($Info[9])."$Size KB
- + - +
+
- + - +
"; =20 print < -
$Lang::tr{'= backupwarning'}


-$Lang::tr{'backup'}
-$Lang::tr{'backupaddon'} + +
$Lang::tr{'bac= kupwarning'}


+ + + + $Lang::tr{'backup'} + +
+ + + + +
+ + + + $Lang::tr{'backupaddon'} +
+ + + + +
+ + END ; diff --git a/langs/de/cgi-bin/de.pl b/langs/de/cgi-bin/de.pl index 95af3155b..37f0cab8a 100644 --- a/langs/de/cgi-bin/de.pl +++ b/langs/de/cgi-bin/de.pl @@ -158,6 +158,7 @@ 'add-route' =3D> 'Zus=C3=A4tzlich zu propagierende Route', 'added from dhcp lease list' =3D> 'hinzugef=C3=BCgt von der DHCP-Zuordnungsl= iste', 'addon' =3D> 'Add-Ons', +'addonbackup' =3D> 'Sichern', 'addons' =3D> 'Add-Ons', 'admin user password has been changed' =3D> 'Passwort f=C3=BCr Benutzer admi= n wurde ge=C3=A4ndert.', 'admin users' =3D> 'Liste der Benutzer mit Super User Rechten', @@ -470,8 +471,11 @@ 'backup sets' =3D> 'Datensicherungss=C3=A4tze', 'backup to floppy' =3D> 'Datensicherung auf Diskette', 'backupaddon' =3D> 'Add-On-Sicherung', +'backup config' =3D> 'Konfiguration', 'backupprofile' =3D> 'Falls die Wiederverbindung scheitert, auf dieses Profi= l umschalten', 'backups' =3D> 'Sicherungen', +'backups data' =3D> 'IPF-Dateien', +'backups iso' =3D> 'ISO-Dateien', 'backupwarning' =3D> 'Spielen Sie zuerst Ihre Hauptsicherung und anschlie=C3= =9Fend die Sicherung(en) der Addon-Konfiguration(en) ein.
Es werden ledi= glich die gesicherten Konfigurationsdatei(en) der Addons, nicht die installie= rten Addons wiederhergestellt!
Achten Sie au=C3=9Ferdem darauf, dass die= Sicherungen ihre originalen Dateinamen behalten.', 'bad characters in' =3D> 'Ung=C3=BCltige Zeichen in ', 'bad characters in script field' =3D> 'Nicht erlaubte Zeichen im Skriptnamen= ', @@ -735,6 +739,8 @@ 'defaultwarning' =3D> 'ACHTUNG - Ihre Einstellungen gehen hiermit verloren u= nd werden durch die Standarteinstellungen ersetzt.', 'delete' =3D> 'L=C3=B6schen', 'delete cron' =3D> 'Cronjob l=C3=B6schen', +'delete file' =3D> 'M=C3=B6chten Sie diese Datei wirklich l=C3=B6schen?', +'delete item' =3D> 'M=C3=B6chten Sie diesen Eintrag wirklich l=C3=B6schen?', 'delete pc' =3D> 'PC l=C3=B6schen', 'delete share' =3D> 'Freigabe l=C3=B6schen', 'delete user' =3D> 'Benutzer l=C3=B6schen', @@ -1600,7 +1606,6 @@ 'logging' =3D> 'Protokollierung', 'logging server' =3D> 'Protokollierungsserver', 'loginlogout' =3D> 'Login/Logout', -'logs' =3D> 'Protokolldateien', 'loosedirectorychecking' =3D> 'Loose directorychecking', 'low' =3D> 'Niedrig', 'ls_dhcpd' =3D> 'DHCP-Server:', @@ -2136,6 +2141,7 @@ 'restart' =3D> 'Neustart', 'restart ovpn server' =3D> 'OpenVPN-Server neu starten', 'restore' =3D> 'Wiederherstellen', +'restoreaddon' =3D> 'Wiederherstellen (Addon)', 'restore defaults' =3D> 'Voreinstellungen wiederherstellen', 'restore hardware settings' =3D> 'Hardwareeinstellungen wiederherstellen', 'restore settings' =3D> 'Einstellungen wiederherstellen', diff --git a/langs/en/cgi-bin/en.pl b/langs/en/cgi-bin/en.pl index d86705772..a126b11ef 100644 --- a/langs/en/cgi-bin/en.pl +++ b/langs/en/cgi-bin/en.pl @@ -155,6 +155,7 @@ 'add xtaccess' =3D> 'Add External Access', 'add-route' =3D> 'Additional push route', 'added from dhcp lease list' =3D> 'Added from DHCP lease list', +'addonbackup' =3D> 'Backup', 'addons' =3D> 'Addons', 'admin user password has been changed' =3D> 'Admin user password has been ch= anged.', 'admin users' =3D> 'User with superuser rights', @@ -459,6 +460,7 @@ 'backup' =3D> 'Backup', 'backup archive' =3D> 'Backup File (.dat)', 'backup clear archive' =3D> 'Clear Backup File (.gz)', +'backup config' =3D> 'Configuration', 'backup config floppy' =3D> 'Backup Configuration - Floppy Disk', 'backup configuration' =3D> 'Backup Configuration:', 'backup erase key' =3D> 'Erase key', @@ -486,6 +488,8 @@ 'backupaddon' =3D> 'Addon Backup', 'backupprofile' =3D> 'In case reconnection fails, switch to profile', 'backups' =3D> 'backups', +'backups data' =3D> 'IPF-Files', +'backups iso' =3D> 'ISO-Files', 'backupwarning' =3D> 'Import your main backup first and then the backup(s) o= f the addon configuration(s).
Only the backed up addon configuration fil= e(s) will be restored, not the installed addons!
Also make sure that the= backups keep their original file names.', 'bad characters in' =3D> 'Bad characters in ', 'bad characters in script field' =3D> 'Bad characters in script field', @@ -755,6 +759,8 @@ 'delete pc' =3D> 'Delete workstation', 'delete share' =3D> 'Delete share', 'delete user' =3D> 'Delete user', +'delete file' =3D> 'Do you really want to delete this file?', +'delete item' =3D> 'Do you really want to delete this item?', 'demon login script' =3D> 'Demon login script', 'deprecated fs warn' =3D> 'Deprecated filesystem! Newer kernel drop the supp= ort. Backup and reformat!', 'description' =3D> 'Description', @@ -1632,7 +1638,6 @@ 'logging' =3D> 'Logging', 'logging server' =3D> 'Logging Server', 'loginlogout' =3D> 'Login/Logout', -'logs' =3D> 'logs', 'loosedirectorychecking' =3D> 'Loosedirectorychecking', 'low' =3D> 'Low', 'ls_dhcpd' =3D> 'DHCP Server:', @@ -2172,6 +2177,7 @@ 'restart' =3D> 'Restart', 'restart ovpn server' =3D> 'Restart OpenVPN server', 'restore' =3D> 'Restore', +'restoreaddon' =3D> 'Restore (Addon)', 'restore defaults' =3D> 'Restore defaults', 'restore hardware settings' =3D> 'Restore hardware settings', 'restore settings' =3D> 'Reset Settings', diff --git a/langs/es/cgi-bin/es.pl b/langs/es/cgi-bin/es.pl index c9a7496bc..fa346233f 100644 --- a/langs/es/cgi-bin/es.pl +++ b/langs/es/cgi-bin/es.pl @@ -1149,7 +1149,6 @@ 'logging' =3D> 'Conectando', 'logging server' =3D> 'Servidor de conexi=C3=B3n', 'loginlogout' =3D> 'Login/Logout', -'logs' =3D> 'registros', 'loosedirectorychecking' =3D> 'Chequeo de loosedirectory', 'low' =3D> 'Bajo', 'ls_dhcpd' =3D> 'Servidor DHCP:', diff --git a/langs/fr/cgi-bin/fr.pl b/langs/fr/cgi-bin/fr.pl index 301109477..ea5985315 100644 --- a/langs/fr/cgi-bin/fr.pl +++ b/langs/fr/cgi-bin/fr.pl @@ -1633,7 +1633,6 @@ 'logging' =3D> 'Connexion', 'logging server' =3D> 'Serveur de connexion', 'loginlogout' =3D> 'Connexion/Quitter', -'logs' =3D> 'Journaux', 'loosedirectorychecking' =3D> 'Echec de la v=C3=A9rification du r=C3=A9perto= ire', 'low' =3D> 'Bas', 'ls_dhcpd' =3D> 'Serveur DHCP :', diff --git a/langs/it/cgi-bin/it.pl b/langs/it/cgi-bin/it.pl index e82ecfd35..711b4bd4a 100644 --- a/langs/it/cgi-bin/it.pl +++ b/langs/it/cgi-bin/it.pl @@ -1408,7 +1408,6 @@ 'logging' =3D> 'Logging', 'logging server' =3D> 'Logging Server', 'loginlogout' =3D> 'Login/Logout', -'logs' =3D> 'Gestione Log', 'loosedirectorychecking' =3D> 'Loosedirectorychecking', 'low' =3D> 'Basso', 'ls_dhcpd' =3D> 'DHCP Server:', diff --git a/langs/nl/cgi-bin/nl.pl b/langs/nl/cgi-bin/nl.pl index 55927839e..aea5e81b5 100644 --- a/langs/nl/cgi-bin/nl.pl +++ b/langs/nl/cgi-bin/nl.pl @@ -1390,7 +1390,6 @@ 'logging' =3D> 'Logging', 'logging server' =3D> 'Loggingserver', 'loginlogout' =3D> 'Login/Logout', -'logs' =3D> 'logs', 'loosedirectorychecking' =3D> 'Loosedirectorychecking', 'low' =3D> 'Laag', 'ls_dhcpd' =3D> 'DHCP Server:', diff --git a/langs/pl/cgi-bin/pl.pl b/langs/pl/cgi-bin/pl.pl index 147db051c..604a834a7 100644 --- a/langs/pl/cgi-bin/pl.pl +++ b/langs/pl/cgi-bin/pl.pl @@ -1094,7 +1094,6 @@ 'logging' =3D> 'Logowanie', 'logging server' =3D> 'Serwer logowania', 'loginlogout' =3D> 'Zalogowanie/wylogowanie', -'logs' =3D> 'logi', 'loosedirectorychecking' =3D> 'Loosedirectorychecking', 'low' =3D> 'Niski', 'ls_dhcpd' =3D> 'Serwer DHCP:', diff --git a/langs/ru/cgi-bin/ru.pl b/langs/ru/cgi-bin/ru.pl index 0d986135d..26ad6c338 100644 --- a/langs/ru/cgi-bin/ru.pl +++ b/langs/ru/cgi-bin/ru.pl @@ -1087,7 +1087,6 @@ 'logging' =3D> 'Logging', 'logging server' =3D> '=D0=A1=D0=B5=D1=80=D0=B2=D0=B5=D1=80 =D0=9B=D0=BE=D0= =B3=D0=BE=D0=B2', 'loginlogout' =3D> 'Login/Logout', -'logs' =3D> '=D0=9B=D0=BE=D0=B3=D0=B8', 'loosedirectorychecking' =3D> 'Loosedirectorychecking', 'low' =3D> 'Low', 'ls_dhcpd' =3D> 'DHCP =D1=81=D0=B5=D1=80=D0=B2=D0=B5=D1=80:', diff --git a/langs/tr/cgi-bin/tr.pl b/langs/tr/cgi-bin/tr.pl index 36c4782d6..233de0995 100644 --- a/langs/tr/cgi-bin/tr.pl +++ b/langs/tr/cgi-bin/tr.pl @@ -1538,7 +1538,6 @@ 'logging' =3D> 'G=C3=BCnl=C3=BCk', 'logging server' =3D> 'G=C3=BCnl=C3=BCk Sunucusu', 'loginlogout' =3D> 'Giri=C5=9F/=C3=87=C4=B1k=C4=B1=C5=9F', -'logs' =3D> 'G=C3=BCnl=C3=BCkler', 'loosedirectorychecking' =3D> 'Serbest Dizin Denetimi', 'low' =3D> 'D=C3=BC=C5=9F=C3=BCk', 'ls_dhcpd' =3D> 'DHCP Sunucusu:', --=20 2.18.0 --===============6975769050322198388==--