IP::Authority - fast lookup of authority by IP address


IP-Country documentation  | view source Contained in the IP-Country distribution.

Index


NAME

Top

IP::Authority - fast lookup of authority by IP address

SYNOPSIS

Top

  use IP::Authority;
  my $reg = IP::Authority->new();
  print $reg->inet_atoauth('212.67.197.128')   ."\n";
  print $reg->inet_atoauth('www.slashdot.org') ."\n";

DESCRIPTION

Top

Historically, the former InterNIC managed (under the auspices of IANA) the allocation of IP numbers to ISPs and other organizations. This changed somewhat when the Regional Internet Registry system was started, with the creation of three (and later, four) Regional Internet Registries (RIRs) around the world, each managing the allocation of IP addresses to organizations within differing physical areas (see also RFC2050).

This means that there is no central whois database for IP numbers.

This module allows the user to lookup the RIR who has authority for a particular IP address. After finding out the authority for an IP address, it is possible to use the authority's whois server to lookup the netblock owner.

CONSTRUCTOR

Top

The constructor takes no arguments.

  use IP::Authority;
  my $reg = IP::Authority->new();

OBJECT METHODS

Top

All object methods are designed to be used in an object-oriented fashion.

  $result = $object->foo_method($bar,$baz);

Using the module in a procedural fashion (without the arrow syntax) won't work.

$auth = $reg->inet_atoauth(HOSTNAME)

Takes a string giving the name of a host, and translates that to an two-letter string representing the regional Internet registry that has authority of that IP address:

  AR = ARIN (North America)
  RI = RIPE (Europe)
  LA = LACNIC (Latin America)
  AP = APNIC (Asia-Pacific)
  AF = AFRINIC (Africa and Indian Ocean)
  IA = IANA (see RFC3330)

Takes arguments of both the 'rtfm.mit.edu' type and '18.181.0.24'. If the host name cannot be resolved, returns undef. If the resolved IP address is not contained within the database, returns undef. For multi-homed hosts (hosts with more than one address), the first address found is returned.

$auth = $reg->inet_ntoauth(IP_ADDRESS)

Takes a string (an opaque string as returned by Socket::inet_aton()) and translates it into a two-letter string representing the regional Internet registry that has authority of that IP address:

  AR = ARIN (North America)
  RI = RIPE (Europe)
  LA = LACNIC (Latin America)
  AP = APNIC (Asia-Pacific)
  AF = AFRINIC (Africa and Indian Ocean)
  IA = IANA (see RFC3330)

If the IP address is not contained within the database, returns undef.

$t = $reg->db_time()

Returns the creation date of the database, measured as number of seconds since the Unix epoch (00:00:00 GMT, January 1, 1970). Suitable for feeding to "gmtime" and "localtime".

BUGS/LIMITATIONS

Top

Only works with IPv4 addresses and ASCII hostnames.

SEE ALSO

Top

IP::Country - fast lookup of country codes from IP address.

http://www.apnic.net - Asia-Pacific

http://www.ripe.net - Europe

http://www.arin.net - North America

http://www.lacnic.net - Latin America

http://www.afrinic.net - Africa and Indian Ocean

COPYRIGHT

Top

APNIC conditions of use

Top

The files are freely available for download and use on the condition that APNIC will not be held responsible for any loss or damage arising from the application of the information contained in these reports.

APNIC endeavours to the best of its ability to ensure the accuracy of these reports; however, APNIC makes no guarantee in this regard.

In particular, it should be noted that these reports seek to indicate the country where resources were first allocated or assigned. It is not intended that these reports be considered as an authoritative statement of the location in which any specific resource may currently be in use.

ARIN database copyright

Top

RIPE database copyright

Top

LACNIC database copyright

Top

AFRINIC copyright

Top


IP-Country documentation  | view source Contained in the IP-Country distribution.