✓ Verified 📊 Data Processing ✓ Enhanced Data

Ipinfo

Perform IP geolocation lookups using ipinfo.io API.

Rating
4.9 (406 reviews)
Downloads
8,145 downloads
Version
1.0.0

Overview

Perform IP geolocation lookups using ipinfo.io API.

Complete Documentation

View Source →

IPinfo Geolocation

Free IP geolocation API. No API key required for basic usage (50k requests/month), optional token for higher limits.

Configuration

The IPINFO_TOKEN environment variable is optional - the skill works without it using the free tier. Configure it via the OpenClaw dashboard UI for higher rate limits, or set it manually:

  • Dashboard UI: Configure IPINFO_TOKEN in the OpenClaw dashboard (optional)
  • Environment variable: export IPINFO_TOKEN="your-token"
  • Query parameter: ?token=YOUR_TOKEN (for one-off requests)

Quick Lookup

Single IP:

bash
curl -s "https://ipinfo.io/8.8.8.8"

Current IP:

bash
curl -s "https://ipinfo.io/json"

With token (optional, from environment):

bash
curl -s "https://ipinfo.io/8.8.8.8?token=${IPINFO_TOKEN}"

Or pass token directly:

bash
curl -s "https://ipinfo.io/8.8.8.8?token=YOUR_TOKEN"

Response Format

JSON response includes:

  • ip: IP address
  • hostname: Reverse DNS hostname
  • city: City name
  • region: State/region
  • country: Two-letter country code (ISO 3166-1 alpha-2)
  • postal: Postal/ZIP code
  • timezone: IANA timezone
  • loc: Coordinates as "latitude,longitude"
  • org: Organization/ASN information

Extract Specific Fields

Using jq:

bash
curl -s "https://ipinfo.io/8.8.8.8" | jq -r '.city, .country, .loc'

Country only:

bash
curl -s "https://ipinfo.io/8.8.8.8" | jq -r '.country'

Parse coordinates:

bash
curl -s "https://ipinfo.io/8.8.8.8" | jq -r '.loc' | tr ',' '\n'

Batch Processing

Process multiple IPs:

bash
for ip in 8.8.8.8 1.1.1.1 208.67.222.222; do
  if [ -n "$IPINFO_TOKEN" ]; then
    echo "$ip: $(curl -s "https://ipinfo.io/$ip?token=$IPINFO_TOKEN" | jq -r '.city, .country' | tr '\n' ', ')"
  else
    echo "$ip: $(curl -s "https://ipinfo.io/$ip" | jq -r '.city, .country' | tr '\n' ', ')"
  fi
done

Python Usage

python
import os
import requests

# Without token (free tier)
response = requests.get("https://ipinfo.io/8.8.8.8")
data = response.json()
print(f"{data['city']}, {data['country']}")
print(f"Coordinates: {data['loc']}")

With token from environment:

python
import os
import requests

token = os.getenv("IPINFO_TOKEN")
if token:
    response = requests.get("https://ipinfo.io/8.8.8.8", params={"token": token})
else:
    response = requests.get("https://ipinfo.io/8.8.8.8")
data = response.json()

Or pass token directly:

python
response = requests.get("https://ipinfo.io/8.8.8.8", params={"token": "YOUR_TOKEN"})

Rate Limits

  • Free tier: 50,000 requests/month, ~1 req/sec
  • With token: Higher limits based on plan
  • Configure IPINFO_TOKEN via OpenClaw dashboard UI or environment variable

Common Use Cases

  • Geolocate IP addresses
  • Enrich IP lists with location data
  • Filter IPs by country
  • Calculate distances between IPs using coordinates
  • Timezone detection for IPs

Installation

Terminal bash

openclaw install ipinfo
    
Copied!

💻Code Examples

curl -s "https://ipinfo.io/8.8.8.8?token=YOUR_TOKEN"

curl--s-httpsipinfoio8888tokenyourtoken.txt
## Response Format

JSON response includes:

- `ip`: IP address
- `hostname`: Reverse DNS hostname
- `city`: City name
- `region`: State/region
- `country`: Two-letter country code (ISO 3166-1 alpha-2)
- `postal`: Postal/ZIP code
- `timezone`: IANA timezone
- `loc`: Coordinates as "latitude,longitude"
- `org`: Organization/ASN information

## Extract Specific Fields

Using `jq`:

curl -s "https://ipinfo.io/8.8.8.8" | jq -r '.loc' | tr ',' '\n'

curl--s-httpsipinfoio8888--jq--r-loc--tr--n.txt
## Batch Processing

Process multiple IPs:
example.sh
for ip in 8.8.8.8 1.1.1.1 208.67.222.222; do
  if [ -n "$IPINFO_TOKEN" ]; then
    echo "$ip: $(curl -s "https://ipinfo.io/$ip?token=$IPINFO_TOKEN" | jq -r '.city, .country' | tr '\n' ', ')"
  else
    echo "$ip: $(curl -s "https://ipinfo.io/$ip" | jq -r '.city, .country' | tr '\n' ', ')"
  fi
done
example.py
import os
import requests

# Without token (free tier)
response = requests.get("https://ipinfo.io/8.8.8.8")
data = response.json()
print(f"{data['city']}, {data['country']}")
print(f"Coordinates: {data['loc']}")
example.py
import os
import requests

token = os.getenv("IPINFO_TOKEN")
if token:
    response = requests.get("https://ipinfo.io/8.8.8.8", params={"token": token})
else:
    response = requests.get("https://ipinfo.io/8.8.8.8")
data = response.json()

⚙️Configuration Options

Option Type Default Description
IPINFO_TOKENstring-environment variable is **optional** - the skill works without it using the free tier. Configure it via the OpenClaw dashboard UI for higher rate limits, or set it manually:
IPINFO_TOKENstring-in the OpenClaw dashboard (optional)

Tags

#data_and-analytics #api

Quick Info

Category Data Processing
Model Claude 3.5
Complexity One-Click
Author tiagom101
Last Updated 3/10/2026
🚀
Optimized for
Claude 3.5
🧠

Ready to Install?

Get started with this skill in seconds

openclaw install ipinfo