From mboxrd@z Thu Jan 1 00:00:00 1970 From: Peter =?utf-8?q?M=C3=BCller?= To: development@lists.ipfire.org Subject: Re: [PATCH v2] add GeoIP and rDNS information to used nameservers Date: Mon, 20 Nov 2017 19:15:24 +0100 Message-ID: <20171120191524.523a185a.peter.mueller@link38.eu> In-Reply-To: <1511193833.4838.544.camel@ipfire.org> MIME-Version: 1.0 Content-Type: multipart/mixed; boundary="===============1769173067252119469==" List-Id: --===============1769173067252119469== Content-Type: text/plain; charset="utf-8" Content-Transfer-Encoding: quoted-printable Hello Michael, > On Thu, 2017-11-16 at 17:23 +0100, Peter M=C3=BCller wrote: > > Hello Michael, > > =20 > > > Hi, > > >=20 > > > On Wed, 2017-11-15 at 22:49 +0100, Peter M=C3=BCller wrote: =20 > > > > Add GeoIP and rDNS information to DNS nameserver list at netexternal.= cgi > > > >=20 > > > > Use newly implemented GeoIP function in /var/ipfire/geoip-functions.pl > > > >=20 > > > > Signed-off-by: Peter M=C3=BCller > > > > --- > > > > html/cgi-bin/netexternal.cgi | 27 ++++++++++++++++++++++++++- > > > > langs/de/cgi-bin/de.pl | 1 + > > > > langs/en/cgi-bin/en.pl | 1 + > > > > 3 files changed, 28 insertions(+), 1 deletion(-) > > > >=20 > > > > diff --git a/html/cgi-bin/netexternal.cgi b/html/cgi-bin/netexternal.= cgi > > > > index 299612d4c..4393393e0 100644 > > > > --- a/html/cgi-bin/netexternal.cgi > > > > +++ b/html/cgi-bin/netexternal.cgi > > > > @@ -25,9 +25,12 @@ use strict; > > > > #use warnings; > > > > #use CGI::Carp 'fatalsToBrowser'; > > > > =20 > > > > +use IO::Socket; > > > > + =20 > > >=20 > > > For what is this module being loaded? =20 > >=20 > > It is necessary to perform the DNS query. Without it, Perl returns > > an error. =20 >=20 > Oh, so inet_aton() is from that package. Would it not be better to call tha= t by > it's full name (IO::Socket::inet_aton)? >=20 > -Michael Probably, but since PTR lookups are performed this way in other CGIs such as ipinfo.cgi, I wanted to stay consistent here. All other patches of the GeoIP bundle are not affected by this. Best regards, Peter M=C3=BCller >=20 > >=20 > > Best regards, > > Peter M=C3=BCller =20 > > > =20 > > > > require '/var/ipfire/general-functions.pl'; > > > > require "${General::swroot}/lang.pl"; > > > > require "${General::swroot}/header.pl"; > > > > +require "${General::swroot}/geoip-functions.pl"; > > > > require "${General::swroot}/graphs.pl"; > > > > =20 > > > > my %color =3D (); > > > > @@ -99,6 +102,12 @@ if ( $querry[0] ne~ ""){ > > > > $Lang::tr{'namese > > > > rver > > > > '} > > > > > > > > > > > > + $Lang::tr{'countr > > > > y'}< =20 > > > > /strong> =20 > > > > + > > > > + > > > > + $Lang::tr{'rdns'} > > > > > > > rong> =20 > > > > + > > > > + > > > > $Lang::tr{'status > > > > '} > > > strong> =20 > > > > > > > > > > > > @@ -139,9 +148,25 @@ END > > > > =20 > > > > my $table_colour =3D ($id++ % 2) ? $color{'color22'} : > > > > $color{'color20'}; > > > > =20 > > > > + # collect more information about name server (rDNS, GeoIP > > > > country code) > > > > + my $ccode =3D &GeoIP::lookup($nameserver); > > > > + my $flag_icon =3D &GeoIP::get_flag_icon($ccode); > > > > + > > > > + my $iaddr =3D inet_aton($nameserver); > > > > + my $rdns =3D gethostbyaddr($iaddr, AF_INET); > > > > + if (!$rdns) { $rdns =3D $Lang::tr{'lookup failed'}; } > > > > + > > > > print < > > > > > > > - $nameserver > > > > + > > > > + $nameserver > > > > + > > > > + > > > > + > > > src=3D"$flag_icon" border=3D"0" alt=3D"$ccode" title=3D"$ccode" /> > > > > + > > > > + > > > > + $rdns > > > > + > > > > > > > > > > > color=3D"$colour">$message =20 > > > > > > > > diff --git a/langs/de/cgi-bin/de.pl b/langs/de/cgi-bin/de.pl > > > > index 6dff5d781..ae87464d2 100644 > > > > --- a/langs/de/cgi-bin/de.pl > > > > +++ b/langs/de/cgi-bin/de.pl > > > > @@ -1962,6 +1962,7 @@ > > > > 'read bytes' =3D> 'Gelesene Bytes', > > > > 'read list' =3D> 'Liste der Leseberechtigten', > > > > 'real address' =3D> 'Reale Addresse', > > > > +'rdns' =3D> 'rDNS', > > > > 'reboot' =3D> 'Neustart', > > > > 'reboot ask' =3D> 'Neustart?', > > > > 'reboot question' =3D> 'Extra Abfrage bei neustart und herunterfahren > > > > einschalten', > > > > diff --git a/langs/en/cgi-bin/en.pl b/langs/en/cgi-bin/en.pl > > > > index 4efff6e65..3af17d5dc 100644 > > > > --- a/langs/en/cgi-bin/en.pl > > > > +++ b/langs/en/cgi-bin/en.pl > > > > @@ -1997,6 +1997,7 @@ > > > > 'quick playlist' =3D> 'Quick Playlist', > > > > 'ram' =3D> 'RAM', > > > > 'random number generator daemon' =3D> 'Random Number Generator Daemo= n', > > > > +'rdns' =3D> 'rDNS', > > > > 'read bytes' =3D> 'Read Bytes', > > > > 'read list' =3D> 'list with readonly hosts', > > > > 'real address' =3D> 'Real Address', =20 > >=20 > > =20 --===============1769173067252119469==--