]> git.ipfire.org Git - people/teissler/ipfire-2.x.git/blob - config/backup/backup.pl
Merge remote-tracking branch 'origin/next' into fifteen
[people/teissler/ipfire-2.x.git] / config / backup / backup.pl
1 #!/usr/bin/perl
2 ###############################################################################
3 # #
4 # IPFire.org - A linux based firewall #
5 # Copyright (C) 2007 Michael Tremer & Christian Schmidt #
6 # #
7 # This program is free software: you can redistribute it and/or modify #
8 # it under the terms of the GNU General Public License as published by #
9 # the Free Software Foundation, either version 3 of the License, or #
10 # (at your option) any later version. #
11 # #
12 # This program is distributed in the hope that it will be useful, #
13 # but WITHOUT ANY WARRANTY; without even the implied warranty of #
14 # MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the #
15 # GNU General Public License for more details. #
16 # #
17 # You should have received a copy of the GNU General Public License #
18 # along with this program. If not, see <http://www.gnu.org/licenses/>. #
19 # #
20 ###############################################################################
21
22 require '/var/ipfire/general-functions.pl';
23 require "${General::swroot}/lang.pl";
24 require "${General::swroot}/header.pl";
25 use File::Path;
26 my $debug = 1;
27 my @include = "";
28 my ($Sekunden, $Minuten, $Stunden, $Monatstag, $Monat, $Jahr, $Wochentag, $Jahrestag, $Sommerzeit) = localtime(time);
29 $Jahr = $Jahr + 1900;$Monat = $Monat + 1;
30 $Monat = sprintf("%02d", $Monat);
31 $Monatstag = sprintf("%02d", $Monatstag);
32 $Stunden = sprintf("%02d", $Stunden);
33 $Minuten = sprintf("%02d", $Minuten);
34
35 if (($ARGV[0] eq 'include') || ($ARGV[0] eq 'iso')) {
36 &createinclude;
37 my @files = `find / -name *.log* 2>/dev/null`;
38 foreach (@files){
39 push(@include,$_);
40 }
41 my @files = `find /var/log/ -name *messages* 2>/dev/null`;
42 foreach (@files){
43 push(@include,$_);
44 }
45 open(DATEI, ">/tmp/include") || die "Could not save temp include file";
46 print DATEI @include;
47 print "/var/log/messages";
48 close(DATEI);
49 system("tar -cvzf /var/ipfire/backup/$Jahr$Monat$Monatstag-$Stunden$Minuten.ipf --files-from='/tmp/include' --exclude-from='/var/ipfire/backup/exclude' --files-from='/var/ipfire/backup/include.user' --exclude-from='/var/ipfire/backup/exclude.user'");
50 system("rm /tmp/include");
51 if ($ARGV[0] eq 'iso') {
52 system("/usr/local/bin/backupiso $Jahr$Monat$Monatstag-$Stunden$Minuten &");
53 }
54 }
55 elsif ($ARGV[0] eq 'exclude') {
56 &createinclude;
57 open(DATEI, ">/tmp/include") || die "Could not save temp include file";
58 print DATEI @include;
59 close(DATEI);
60 system("tar -cvzf /var/ipfire/backup/$Jahr$Monat$Monatstag-$Stunden$Minuten.ipf --files-from='/tmp/include' --exclude-from='/var/ipfire/backup/exclude' --files-from='/var/ipfire/backup/include.user' --exclude-from='/var/ipfire/backup/exclude.user'");
61 system("rm /tmp/include");
62 }
63 elsif ($ARGV[0] eq 'restore') {
64 system("cd / && tar -xvz -p -f /tmp/restore.ipf");
65 #Here some converter scripts to correct old Backups (before core 65)
66 system("/usr/sbin/ovpn-ccd-convert");
67 #OUTGOINGFW CONVERTER
68 if( -d "${General::swroot}/outgoing"){
69 if( -f "${General::swroot}/forward/config" ){
70 unlink("${General::swroot}/forward/config");
71 system("touch ${General::swroot}/forward/config");
72 chown 99,99,"${General::swroot}/forward/config";
73 }
74 if( -f "${General::swroot}/forward/outgoing" ){
75 unlink("${General::swroot}/forward/outgoing");
76 system("touch ${General::swroot}/forward/outgoing");
77 chown 99,99,"${General::swroot}/forward/outgoing";
78 }
79 unlink("${General::swroot}/fwhosts/customgroups");
80 unlink("${General::swroot}/fwhosts/customhosts");
81 unlink("${General::swroot}/fwhosts/customgroups");
82 unlink("${General::swroot}/fwhosts/customnetworks");
83 unlink("${General::swroot}/fwhosts/customservicegrp");
84 unlink("${General::swroot}/fwhosts/customnetworks");
85 system("touch ${General::swroot}/fwhosts/customgroups");
86 system("touch ${General::swroot}/fwhosts/customhosts");
87 system("touch ${General::swroot}/fwhosts/customnetworks");
88 system("touch ${General::swroot}/fwhosts/customservicegrp");
89 #START CONVERTER "OUTGOINGFW"
90 system("/usr/sbin/convert-outgoingfw");
91 chown 99,99,"${General::swroot}/fwhosts/customgroups";
92 chown 99,99,"${General::swroot}/fwhosts/customhosts";
93 chown 99,99,"${General::swroot}/fwhosts/customnetworks";
94 chown 99,99,"${General::swroot}/fwhosts/customservicegrp";
95 #START CONVERTER "OUTGOINGFW"
96 rmtree("${General::swroot}/outgoing");
97 }
98 #XTACCESS CONVERTER
99 if( -d "${General::swroot}/xtaccess"){
100 if( -f "${General::swroot}/forward/input" ){
101 unlink("${General::swroot}/forward/input");
102 system("touch ${General::swroot}/forward/input");
103 }
104 #START CONVERTER "XTACCESS"
105 system("/usr/sbin/convert-xtaccess");
106 chown 99,99,"${General::swroot}/forward/input";
107 rmtree("${General::swroot}/xtaccess");
108 }
109 #DMZ-HOLES CONVERTER
110 if( -d "${General::swroot}/dmzholes"){
111 if( -f "${General::swroot}/forward/dmz" ){
112 unlink("${General::swroot}/forward/dmz");
113 system("touch ${General::swroot}/forward/dmz");
114 }
115 #START CONVERTER "DMZ-HOLES"
116 system("/usr/sbin/convert-dmz");
117 chown 99,99,"${General::swroot}/forward/dmz";
118 rmtree("${General::swroot}/dmzholes");
119 }
120 #PORTFORWARD CONVERTER
121 if( -d "${General::swroot}/portfw"){
122 if( -f "${General::swroot}/forward/nat" ){
123 unlink("${General::swroot}/forward/nat");
124 system("touch ${General::swroot}/forward/nat");
125 }
126 #START CONVERTER "PORTFW"
127 system("/usr/sbin/convert-portfw");
128 chown 99,99,"${General::swroot}/forward/nat";
129 rmtree("${General::swroot}/portfw");
130 }
131 system("/usr/local/bin/forwardfwctrl");
132 }
133 elsif ($ARGV[0] eq 'restoreaddon') {
134 if ( -e "/tmp/$ARGV[1]" ){system("mv /tmp/$ARGV[1] /var/ipfire/backup/addons/backup/$ARGV[1]");}
135 system("cd / && tar -xvz -p -f /var/ipfire/backup/addons/backup/$ARGV[1]");
136 }
137 elsif ($ARGV[0] eq 'cli') {
138 system("tar -cvzf /var/ipfire/backup/$Jahr$Monat$Monatstag-$Stunden$Minuten-$ARGV[1].ipf --files-from='$ARGV[2]' --exclude-from='$ARGV[3]'");
139 }
140 elsif ($ARGV[0] eq 'addonbackup') {
141 system("tar -cvzf /var/ipfire/backup/addons/backup/$ARGV[1].ipf --files-from='/var/ipfire/backup/addons/includes/$ARGV[1]'");
142 }
143 elsif ($ARGV[0] =~ /ipf$/ ) {
144 system("rm /var/ipfire/backup/$ARGV[0]");
145 }
146 elsif ($ARGV[0] =~ /iso$/ ) {
147 system("rm /var/tmp/backupiso/$ARGV[0]");
148 }
149 elsif ($ARGV[0] eq '') {
150 printf "No argument given, please use <include><exclude><cli>\n"
151 }
152 elsif ($ARGV[0] eq 'makedirs') {
153 system("mkdir -p /var/ipfire/backup/addons");
154 system("mkdir -p /var/ipfire/backup/addons/backup");
155 system("mkdir -p /var/ipfire/backup/addons/includes");
156 }
157
158 sub createinclude(){
159
160 open(DATEI, "<${General::swroot}/backup/include") || die "Can not open include file";
161 my @Zeilen = <DATEI>;
162 close(DATEI);
163
164 foreach (@Zeilen){
165 if ( $_ =~ /\*/){
166 my @files = `ls $_`;
167 foreach (@files){
168 push(@include,$_);
169 }
170 }
171 else {push(@include,$_);}
172 }
173 }