From: Michael Tremer <michael.tremer@ipfire.org>
To: development@lists.ipfire.org
Subject: Re: [PATCH] display rDNS and GeoIP information for used nameservers
Date: Tue, 07 Nov 2017 11:37:50 +0000 [thread overview]
Message-ID: <1510054670.4838.311.camel@ipfire.org> (raw)
In-Reply-To: <20171106190919.2f0f434f.peter.mueller@link38.eu>
[-- Attachment #1: Type: text/plain, Size: 3922 bytes --]
Hi,
this quite a nice idea, but I have one small problem here which I think could
potentially confuse the users more than it helps.
And that is anycast DNS servers.
So for example for the famous Google DNS 8.8.8.8 the GeoIP location would be US
which technically is correct, but I know for a fact that I am using an instance
that is located in the Telehouse which just a few miles away from me and not on
the other side of the big pond.
So can we do anything to make this better and should we?
-Michael
On Mon, 2017-11-06 at 19:09 +0100, Peter Müller wrote:
> Display rDNS/PTR record and GeoIP information for used nameservers
> on the netexternal.cgi WebUI page. These information might be useful
> for debugging.
>
> Thanks to Matthias Fischer for style improvements.
>
> Signed-off-by: Peter Müller <peter.mueller(a)link38.eu>
> ---
> html/cgi-bin/netexternal.cgi | 25 +++++++++++++++++++++++++
> langs/de/cgi-bin/de.pl | 1 +
> langs/en/cgi-bin/en.pl | 1 +
> 3 files changed, 27 insertions(+)
>
> diff --git a/html/cgi-bin/netexternal.cgi b/html/cgi-bin/netexternal.cgi
> index 299612d4c..cd2223ac6 100644
> --- a/html/cgi-bin/netexternal.cgi
> +++ b/html/cgi-bin/netexternal.cgi
> @@ -25,9 +25,13 @@ use strict;
> #use warnings;
> #use CGI::Carp 'fatalsToBrowser';
>
> +use IO::Socket;
> +use Geo::IP::PurePerl;
> +
> 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";
>
> my %color = ();
> @@ -99,6 +103,12 @@ if ( $querry[0] ne~ ""){
> <strong>$Lang::tr{'nameserver
> '}</strong>
> </th>
> <th align="center">
> + <strong>$Lang::tr{'flag'}</st
> rong>
> + </th>
> + <th align="center">
> + <strong>$Lang::tr{'rdns'}</st
> rong>
> + </th>
> + <th align="center">
> <strong>$Lang::tr{'status'}</
> strong>
> </th>
> </tr>
> @@ -138,10 +148,25 @@ END
> }
>
> my $table_colour = ($id++ % 2) ? $color{'color22'} :
> $color{'color20'};
> +
> + my $iaddr = inet_aton($nameserver);
> + my $rdns = gethostbyaddr($iaddr, AF_INET);
> + if (!$rdns) { $rdns = $Lang::tr{'lookup failed'}; }
> +
> + my $gi = Geo::IP::PurePerl->new();
> + my $ccode = $gi->country_code_by_name($nameserver);
> + my $fcode = lc($ccode);
> + my $flag_icon = &GeoIP::get_flag_icon($fcode);
>
> print <<END;
> <tr bgcolor="$table_colour">
> <td>$nameserver</td>
> + <td align="center">
> + <a href="country.cgi#$fcode"><img
> src="$flag_icon" border="0" align="absmiddle" alt="$ccode" title="$ccode"></a>
> + </td>
> + <td align="center">
> + $rdns
> + </td>
> <td bgcolor="$bgcolour" align="center">
> <font
> color="$colour"><strong>$message</strong></font>
> </td>
> diff --git a/langs/de/cgi-bin/de.pl b/langs/de/cgi-bin/de.pl
> index af96a6445..4cf866a3a 100644
> --- a/langs/de/cgi-bin/de.pl
> +++ b/langs/de/cgi-bin/de.pl
> @@ -1951,6 +1951,7 @@
> 'quick playlist' => 'Quick Playlist',
> 'ram' => 'RAM-Speicher',
> 'random number generator daemon' => 'Random Number Generator Daemon',
> +'rdns' => 'rDNS',
> 'read bytes' => 'Gelesene Bytes',
> 'read list' => 'Liste der Leseberechtigten',
> 'real address' => 'Reale Addresse',
> diff --git a/langs/en/cgi-bin/en.pl b/langs/en/cgi-bin/en.pl
> index 7e4f95ccf..946aba873 100644
> --- a/langs/en/cgi-bin/en.pl
> +++ b/langs/en/cgi-bin/en.pl
> @@ -1989,6 +1989,7 @@
> 'quick playlist' => 'Quick Playlist',
> 'ram' => 'RAM',
> 'random number generator daemon' => 'Random Number Generator Daemon',
> +'rdns' => 'rDNS',
> 'read bytes' => 'Read Bytes',
> 'read list' => 'list with readonly hosts',
> 'real address' => 'Real Address',
[-- Attachment #2: signature.asc --]
[-- Type: application/pgp-signature, Size: 833 bytes --]
next prev parent reply other threads:[~2017-11-07 11:37 UTC|newest]
Thread overview: 6+ messages / expand[flat|nested] mbox.gz Atom feed top
2017-11-06 18:09 Peter Müller
2017-11-07 11:37 ` Michael Tremer [this message]
2017-11-07 19:25 ` Peter Müller
2017-11-07 23:03 ` Michael Tremer
2017-11-08 21:58 ` Peter Müller
2017-11-09 22:41 ` Michael Tremer
Reply instructions:
You may reply publicly to this message via plain-text email
using any one of the following methods:
* Save the following mbox file, import it into your mail client,
and reply-to-all from there: mbox
Avoid top-posting and favor interleaved quoting:
https://en.wikipedia.org/wiki/Posting_style#Interleaved_style
* Reply using the --to, --cc, and --in-reply-to
switches of git-send-email(1):
git send-email \
--in-reply-to=1510054670.4838.311.camel@ipfire.org \
--to=michael.tremer@ipfire.org \
--cc=development@lists.ipfire.org \
/path/to/YOUR_REPLY
https://kernel.org/pub/software/scm/git/docs/git-send-email.html
* If your mail client supports setting the In-Reply-To header
via mailto: links, try the mailto: link
Be sure your reply has a Subject: header at the top and a blank line
before the message body.
This is a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox