]>
git.ipfire.org Git - people/pmueller/ipfire-2.x.git/blob - html/cgi-bin/netexternal.cgi
2 ###############################################################################
4 # IPFire.org - A linux based firewall #
5 # Copyright (C) 2005-2010 IPFire Team #
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. #
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. #
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/>. #
20 ###############################################################################
24 # enable only the following on debugging purpose
26 #use CGI::Carp 'fatalsToBrowser';
28 require '/var/ipfire/general-functions.pl';
29 require "${General::swroot}/lang.pl";
30 require "${General::swroot}/header.pl";
31 require "${General::swroot}/graphs.pl";
34 my %mainsettings = ();
36 &General
::readhash
("${General::swroot}/ethernet/settings", \
%netsettings);
37 &General
::readhash
("${General::swroot}/main/settings", \
%mainsettings);
38 &General
::readhash
("/srv/web/ipfire/html/themes/".$mainsettings{'THEME'}."/include/colors.txt", \
%color);
43 my @querry = split(/\?/,$ENV{'QUERY_STRING'});
44 $querry[0] = '' unless defined $querry[0];
45 $querry[1] = 'hour' unless defined $querry[1];
47 if ( $querry[0] ne~ ""){
48 print "Content-type: image/png\n\n";
50 &Graphs
::updateifgraph
($querry[0],$querry[1]);
53 &Header
::showhttpheaders
();
54 &Header
::openpage
($Lang::tr
{'network traffic graphs external'}, 1, '');
55 &Header
::openbigbox
('100%', 'left');
57 if ($netsettings{'RED_TYPE'} ne 'PPPOE'){
58 if ($netsettings{'RED_DEV'} ne $netsettings{'GREEN_DEV'}){
59 push (@graphs, ($netsettings{'RED_DEV'}));
62 push (@graphs, "ppp0");
65 if (-e
"/var/log/rrd/collectd/localhost/interface/if_octets-ipsec0.rrd"){
66 push (@graphs, ("ipsec0"));
69 if (-e
"/var/log/rrd/collectd/localhost/interface/if_octets-tun0.rrd"){
70 push (@graphs, ("tun0"));
74 &Header
::openbox
('100%', 'center', "$_ $Lang::tr{'graph'}");
75 &Graphs
::makegraphbox
("netexternal.cgi",$_,"day");
81 foreach my $f ("${General::swroot}/red/dns1", "${General::swroot}/red/dns2") {
83 my $nameserver = <DNS
>;
88 push(@nameservers, $nameserver);
92 &Header
::openbox
('100%', 'center', $Lang::tr
{'dnssec information'});
95 <table class="tbl" width='66%'>
99 <strong>$Lang::tr{'nameserver'}</strong>
102 <strong>$Lang::tr{'status'}</strong>
110 for my $nameserver (@nameservers) {
111 my $status = &check_dnssec
($nameserver, "ping.ipfire.org");
116 # DNSSEC Not supported
118 $message = $Lang::tr
{'dnssec not supported'};
119 $colour = ${Header
::colourred
};
122 } elsif ($status == 1) {
123 $message = $Lang::tr
{'dnssec aware'};
124 $colour = ${Header
::colouryellow
};
127 } elsif ($status == 2) {
128 $message = $Lang::tr
{'dnssec validating'};
129 $colour = ${Header
::colourgreen
};
133 $colour = ${Header
::colourred
};
136 my $table_colour = ($id++ % 2) ?
$color{'color22'} : $color{'color20'};
139 <tr bgcolor="$table_colour">
141 <td bgcolor="$colour" align="center">
142 <font color='white'><strong>$message</strong></font>
155 if ( $netsettings{'CONFIG_TYPE'} =~ /^(1|2|3|4)$/ && $netsettings{'RED_TYPE'} eq "DHCP"){
157 &Header
::openbox
('100%', 'left', "RED $Lang::tr{'dhcp configuration'}");
158 if (-s
"${General::swroot}/dhcpc/dhcpcd-$netsettings{'RED_DEV'}.info") {
160 &General
::readhash
("${General::swroot}/dhcpc/dhcpcd-$netsettings{'RED_DEV'}.info", \
%dhcpinfo);
162 my $DNS1=`echo $dhcpinfo{'domain_name_servers'} | cut -f 1 -d " "`;
163 my $DNS2=`echo $dhcpinfo{'domain_name_servers'} | cut -f 2 -d " "`;
167 if ($dhcpinfo{'dhcp_lease_time'} ne "") {
168 $lsetme=$dhcpinfo{'dhcp_lease_time'};
169 $lsetme=($lsetme/60);
172 $lsetme=($lsetme/60); $leasetime=$lsetme." Hour";
174 $leasetime=$lsetme." Minute";
178 $leasetime=$leasetime."s";
185 if ($dhcpinfo{'dhcp_renewal_time'} ne "") {
186 $rentme=$dhcpinfo{'dhcp_renewal_time'};
187 $rentme=($rentme/60);
190 $rentme=($rentme/60); $rnwltime=$rentme." Hour";
192 $rnwltime=$rentme." Minute";
196 $rnwltime=$rnwltime."s";
203 if ($dhcpinfo{'dhcp_rebinding_time'} ne "") {
204 $maxtme=$dhcpinfo{'dhcp_rebinding_time'};
205 $maxtme=($maxtme/60);
208 $maxtme=($maxtme/60); $maxtime=$maxtme." Hour";
210 $maxtime=$maxtme." Minute";
214 $maxtime=$maxtime."s";
221 <tr><td width='30%'>$Lang::tr{'domain'}</td><td>$dhcpinfo{'domain_name'}</td></tr>
222 <tr><td>$Lang::tr{'gateway'}</td><td>$dhcpinfo{'routers'}</td></tr>
223 <tr><td>$Lang::tr{'primary dns'}</td><td>$DNS1</td></tr>
224 <tr><td>$Lang::tr{'secondary dns'}</td><td>$DNS2</td></tr>
225 <tr><td>$Lang::tr{'dhcp server'}</td><td>$dhcpinfo{'dhcp_server_identifier'}</td></tr>
226 <tr><td>$Lang::tr{'def lease time'}</td><td>$leasetime</td></tr>
227 <tr><td>$Lang::tr{'default renewal time'}</td><td>$rnwltime</td></tr>
228 <tr><td>$Lang::tr{'max renewal time'}</td><td>$maxtime</td></tr>
233 print "$Lang::tr{'no dhcp lease'}";
238 &Header
::closebigbox
();
239 &Header
::closepage
();
242 sub check_dnssec
($$) {
243 my $nameserver = shift;
246 my @command = ("dig", "+dnssec", $record, "\@$nameserver");
248 my @output = qx(@command);
249 my $output = join("", @output);
252 if ($output =~ m/status: (\w+)/) {
253 $status = ($1 eq "NOERROR");
261 if ($output =~ m/flags: (.*);/) {
262 @flags = split(/ /, $1);
265 my $aware = ($output =~ m/RRSIG/);
266 my $validating = ("ad" ~~ @flags);
268 return $aware + $validating;