#asn #bgp #ip

app iptoasn-webservice

API server for iptoasn.com

7 releases

0.2.7 Oct 15, 2025
0.2.6 Oct 6, 2025
0.2.5 Aug 1, 2020
0.2.3 Feb 18, 2019
0.2.1 Apr 27, 2017

#673 in Network programming

MIT license

29KB
607 lines

Build Status

iptoasn-webservice

A high-performance HTTP API server that maps IP addresses to Autonomous System (AS) information including ASN, country code, and organization description.

This is the source code of the (previously) public API from iptoasn.com.

Features

  • Fast IP to ASN lookups using efficient binary search over sorted IP ranges
  • Automatic database updates with configurable refresh intervals
  • Robust data loading with fallback mechanisms for offline operation
  • Multiple output formats (JSON and HTML)
  • Built-in caching for downloaded databases
  • Production-ready with proper HTTP headers and error handling

Requirements

  • Rust (latest stable)

Installation & Usage

Build from source

cargo build --release

Run the server

# Default configuration (listen on 127.0.0.1:53661, refresh every 60 minutes)
./target/release/iptoasn-webservice

# Custom configuration
./target/release/iptoasn-webservice \
  --listen 0.0.0.0:8080 \
  --dburl https://iptoasn.com/data/ip2asn-combined.tsv.gz \
  --refresh 120

Command line options

  • --listen (-l): Address and port to bind to (default: 127.0.0.1:53661)
  • --dburl (-u): Database URL to download from (default: https://iptoasn.com/data/ip2asn-combined.tsv.gz)
  • --refresh (-r): Database refresh interval in minutes, 0 to disable (default: 60)

API Usage

Routes

  • /v1/as/ip/<ip address>
    • Lookup provided IP address
  • /v1/as/ip
    • Lookup requester's IP address, prioritized as X-Real-IP > X-Forwarded-For > Request IP

JSON Response

curl -H'Accept: application/json' http://localhost:53661/v1/as/ip/8.8.8.8
{
  "announced": true,
  "as_country_code": "US",
  "as_description": "GOOGLE - Google LLC",
  "as_number": 15169,
  "first_ip": "8.8.8.0",
  "ip": "8.8.8.8",
  "last_ip": "8.8.8.255"
}

HTML Response

curl http://localhost:53661/v1/as/ip/8.8.8.8

Returns a formatted HTML page with the IP information.

Unannounced IPs

For IP addresses not found in BGP announcements:

{
  "announced": false,
  "ip": "127.0.0.1"
}

Data Source

The service downloads and processes the IP-to-ASN mapping database from iptoasn.com, which provides comprehensive BGP routing table data updated regularly. The database is automatically cached locally and the service includes fallback mechanisms to continue operating even when the remote database is unavailable.

Dependencies

~19–39MB
~506K SLoC