mirror of
https://github.com/vincentmli/bpfire.git
synced 2026-04-27 03:07:43 +02:00
Am Pakfire weitergearbeitet.
CGI erweitert und mit neuen Funktionen versehen. Paketformat grundlegend geaendert. UpdateBooster gefixt. Avira+Avast als Updatequelle eingefuegt. VPN-Watch ins log.dat. DHCP-Server startet nach der Installation. Einen String im Installer verschoenert :D git-svn-id: http://svn.ipfire.org/svn/ipfire/trunk@639 ea5c0bd1-69bd-2848-81d8-4f18e57aeed8
This commit is contained in:
@@ -62,7 +62,7 @@ my %sections = (
|
||||
'ssh' => '(sshd(?:\(.*\))?\[.*\])',
|
||||
'auth' => '(\w+\(pam_unix\)\[.*\])',
|
||||
'kernel' => '(kernel)',
|
||||
'ipsec' => '(ipsec_[\w_]+|pluto\[.*\])',
|
||||
'ipsec' => '(ipsec_[\w_]+|pluto\[.*\]|vpnwatch)',
|
||||
'snort' => '(snort)',
|
||||
'openvpn' => '(openvpnserver)\[.*\]'
|
||||
);
|
||||
|
||||
@@ -6,9 +6,6 @@
|
||||
#
|
||||
# This code is distributed under the terms of the GPL
|
||||
#
|
||||
# (c) Eric Oberlander June 2002
|
||||
#
|
||||
# (c) Darren Critchley June 2003 - added real time clock setting, etc
|
||||
#
|
||||
|
||||
use strict;
|
||||
@@ -24,8 +21,6 @@ require "/opt/pakfire/lib/functions.pl";
|
||||
|
||||
my %pakfiresettings=();
|
||||
my $errormessage = '';
|
||||
my @instlist = `ls /opt/pakfire/cache`;
|
||||
my $uninstall = 'yes';
|
||||
|
||||
&Header::showhttpheaders();
|
||||
|
||||
@@ -42,20 +37,53 @@ $pakfiresettings{'AUTOUPDATE'} = '';
|
||||
&Header::openbigbox('100%', 'left', '', $errormessage);
|
||||
|
||||
if ($pakfiresettings{'ACTION'} eq 'install'){
|
||||
print "Going to install $pakfiresettings{'INSPAKS'}";
|
||||
system("/opt/pakfire/pakfire installi $pakfiresettings{'INSPAKS'}")
|
||||
}elsif ($pakfiresettings{'ACTION'} eq 'remove'){
|
||||
foreach (@instlist){
|
||||
my @pakname = split(/-/,$_);
|
||||
my $dependency = `grep "Dependencies.*$pakfiresettings{'DELPAKS'}" /opt/pakfire/db/meta/*$pakname[0]`;
|
||||
if ($dependency){$errormessage = "We have depending Paket $pakname[0] nothing will be done.<br />";$uninstall='no';last;}else{$uninstall='yes';}
|
||||
}
|
||||
if ($uninstall eq 'yes'){
|
||||
print "Going to uninstall $pakfiresettings{'DELPAKS'}";
|
||||
system("/opt/pakfire/pakfire uninstalli $pakfiresettings{'DELPAKS'}")
|
||||
}
|
||||
} elsif ($pakfiresettings{'ACTION'} eq "$Lang::tr{'save'}")
|
||||
{
|
||||
if ("$pakfiresettings{'FORCE'}" eq "on") {
|
||||
system("/usr/local/bin/pakfire", "install", "--non-interactive", "$pakfiresettings{'INSPAKS'}", "&");
|
||||
sleep(1);
|
||||
} else {
|
||||
&Header::openbox("100%", "center", "Abfrage");
|
||||
my @output = `/usr/local/bin/pakfire resolvedeps $pakfiresettings{'INSPAKS'}`;
|
||||
print <<END;
|
||||
<table><tr><td colspan='2'>Sie maechten folgende Pakete installieren: $pakfiresettings{'INSPAKS'}. Moeglicherweise haben diese Pakete Abhaengigkeiten, d.h. andere Pakete muessen zusaetzlich installiert werden. Dazu sehen sie unten eine Liste.
|
||||
<pre>
|
||||
END
|
||||
foreach (@output) {
|
||||
print "$_\n";
|
||||
}
|
||||
print <<END;
|
||||
</pre>
|
||||
<tr><td colspan='2'>Moechten Sie der Installation aller Pakete zustimmen?
|
||||
<tr><td colspan='2'>
|
||||
<tr><td align='right'><form method='post' action='$ENV{'SCRIPT_NAME'}'>
|
||||
<input type='hidden' name='INSPAKS' value='$pakfiresettings{'INSPAKS'}' />
|
||||
<input type='hidden' name='FORCE' value='on' />
|
||||
<input type='hidden' name='ACTION' value='install' />
|
||||
<input type='image' alt='$Lang::tr{'install'}' src='/images/go-next.png' />
|
||||
</form>
|
||||
<td align='left'>
|
||||
<form method='post' action='$ENV{'SCRIPT_NAME'}'>
|
||||
<input type='hidden' name='ACTION' value='' />
|
||||
<input type='image' alt='$Lang::tr{'abort'}' src='/images/dialog-error.png' />
|
||||
</form>
|
||||
</table>
|
||||
END
|
||||
&Header::closebox();
|
||||
&Header::closebigbox();
|
||||
&Header::closepage();
|
||||
exit;
|
||||
}
|
||||
} elsif ($pakfiresettings{'ACTION'} eq 'remove') {
|
||||
|
||||
} elsif ($pakfiresettings{'ACTION'} eq 'update') {
|
||||
|
||||
system("/usr/local/bin/pakfire update --force");
|
||||
|
||||
} elsif ($pakfiresettings{'ACTION'} eq 'unlock') {
|
||||
|
||||
&Pakfire::lock("off");
|
||||
|
||||
} elsif ($pakfiresettings{'ACTION'} eq "$Lang::tr{'save'}") {
|
||||
|
||||
&General::writehash("${General::swroot}/pakfire/settings", \%pakfiresettings);
|
||||
}
|
||||
|
||||
@@ -73,7 +101,30 @@ if ($errormessage) {
|
||||
&Header::openbox('100%', 'left', $Lang::tr{'error messages'});
|
||||
print "<font class='base'>$errormessage </font>\n";
|
||||
&Header::closebox();
|
||||
}
|
||||
}
|
||||
|
||||
if ( -e "/opt/pakfire/pakfire.lock" ) {
|
||||
&Header::openbox("100%", "center", "Aktiv");
|
||||
print <<END;
|
||||
<table>
|
||||
<tr><td>
|
||||
<form method='post' action='$ENV{'SCRIPT_NAME'}'>
|
||||
<input type='hidden' name='ACTION' value='unlock' />
|
||||
<input type='image' src='/images/indicator.gif' alt='$Lang::tr{'aktiv'}' />
|
||||
</form>
|
||||
<td>
|
||||
Pakfire fuehrt gerade eine Aufgabe aus... Bitte warten sie, bis diese erfolgreich beendet wurde.
|
||||
<tr><td colspan='2' align='center'>
|
||||
<form method='post' action='$ENV{'SCRIPT_NAME'}'>
|
||||
<input type='image' alt='$Lang::tr{'reload'}' src='/images/view-refresh.png' />
|
||||
</form>
|
||||
</table>
|
||||
END
|
||||
&Header::closebox();
|
||||
&Header::closebigbox();
|
||||
&Header::closepage();
|
||||
exit;
|
||||
}
|
||||
|
||||
&Header::openbox("100%", "center", "Pakfire");
|
||||
|
||||
@@ -94,6 +145,7 @@ print <<END;
|
||||
</form><br />
|
||||
|
||||
<form method='post' action='$ENV{'SCRIPT_NAME'}'>
|
||||
<input type='hidden' name='ACTION' value='update' />
|
||||
<input type='submit' value='Liste aktualisieren' /><br />
|
||||
</form>
|
||||
|
||||
@@ -104,11 +156,10 @@ print <<END;
|
||||
<td width='40%' align="center">Installierte Addons:<br />
|
||||
<select name="DELPAKS" size="10" multiple>
|
||||
END
|
||||
foreach (@instlist){
|
||||
my @pakname = split(/-/,$_);
|
||||
print "<option value='$pakname[0]'>$pakname[0]</option>";
|
||||
}
|
||||
print <<END;
|
||||
|
||||
&Pakfire::dblist("installed", "forweb");
|
||||
|
||||
print <<END;
|
||||
</select>
|
||||
</table></form>
|
||||
<br /><hr /><br />
|
||||
|
||||
@@ -175,7 +175,7 @@ if ($xlratorsettings{'ACTION'} eq $Lang::tr{'updxlrtr save and restart'})
|
||||
|
||||
&savesettings;
|
||||
|
||||
system('/usr/local/bin/restartsquid');
|
||||
system('/usr/local/bin/squidctrl restart');
|
||||
}
|
||||
|
||||
if ($xlratorsettings{'ACTION'} eq $Lang::tr{'updxlrtr remove file'})
|
||||
@@ -456,6 +456,12 @@ END
|
||||
} elsif ($metadata[1] eq 'Symantec')
|
||||
{
|
||||
print "<img src='/images/updxl-src-symantec.gif' alt='Symantec'}' /> </td>\n";
|
||||
} elsif ($metadata[1] eq 'Avira')
|
||||
{
|
||||
print "<img src='/images/updxl-src-avira.gif' alt='Avira'}' /> </td>\n";
|
||||
} elsif ($metadata[1] eq 'Avast')
|
||||
{
|
||||
print "<img src='/images/updxl-src-avast.gif' alt='Avast'}' /> </td>\n";
|
||||
} else
|
||||
{
|
||||
print "<img src='/images/updxl-src-unknown.gif' alt='$Lang::tr{'updxlrtr unknown'}' /> </td>\n";
|
||||
@@ -538,6 +544,16 @@ print <<END
|
||||
<td align='center'><img src='/images/updxl-src-unknown.gif' alt='$Lang::tr{'updxlrtr unknown'}' /></td>
|
||||
<td class='base'>$Lang::tr{'updxlrtr unknown'}</td>
|
||||
</tr>
|
||||
<tr>
|
||||
<td class='base' colspan='2'> </td>
|
||||
<td align='center'><img src='/images/updxl-src-avast.gif' alt='Avast' /></td>
|
||||
<td class='base'>Avast</td>
|
||||
<td class='base'> </td>
|
||||
<td align='center'><img src='/images/updxl-src-avira.gif' alt='Avira' /></td>
|
||||
<td class='base'>Avira</td>
|
||||
<td class='base'> </td>
|
||||
<td class='base' colspan='5'> </td>
|
||||
</tr>
|
||||
</table>
|
||||
END
|
||||
;
|
||||
|
||||
BIN
html/html/images/updxl-src-avast.gif
Normal file
BIN
html/html/images/updxl-src-avast.gif
Normal file
Binary file not shown.
|
After Width: | Height: | Size: 1.1 KiB |
BIN
html/html/images/updxl-src-avira.gif
Normal file
BIN
html/html/images/updxl-src-avira.gif
Normal file
Binary file not shown.
|
After Width: | Height: | Size: 1.0 KiB |
Reference in New Issue
Block a user