getGeolocationForIpAddress
The getGeolocationForIpAddress()
function is used to retrieve geolocation information about the given IP address.
Note: Can only be used when processing requests, not during build-time initialization.
Syntax
getGeolocationForIpAddress(address)
Parameters
address
: string- The IPv4 or IPv6 address to query.
Return value
Returns an Object
, or null
if no geolocation data was found.
The object contains information about the given IP address with the following properties:
as_name
: string | null- The name of the organization associated with
as_number
. - For example, fastly is the value given for IP addresses under AS-54113.
- The name of the organization associated with
as_number
: number | null- Autonomous system (AS) number.
area_code
: number | null- The telephone area code associated with an IP address.
- These are only available for IP addresses in the United States, its territories, and Canada.
city
: string | null- City or town name.
conn_speed
: string | null- Connection speed.
conn_type
: string | null- Connection type.
continent
: string | null- Continent.
country_code
: string | null- A two-character ISO 3166-1 country code for the country associated with an IP address.
- The US country code is returned for IP addresses associated with overseas United States military bases.
- These values include subdivisions that are assigned their own country codes in ISO 3166-1. For example, subdivisions NO-21 and NO-22 are presented with the country code SJ for Svalbard and the Jan Mayen Islands.
country_code3
: string | null- A three-character ISO 3166-1 alpha-3 country code for the country associated with the IP address.
- The USA country code is returned for IP addresses associated with overseas United States military bases.
country_name
: string | null- Country name.
- This field is the ISO 3166-1 English short name for a country.
gmt_offset
: string | null- Time zone offset from Greenwich Mean Time (GMT) for
city
.
- Time zone offset from Greenwich Mean Time (GMT) for
latitude
: number | null- Latitude, in units of degrees from the equator.
- Values range from -90.0 to +90.0 inclusive, and are based on the WGS 84 coordinate reference system.
longitude
: number | null- Longitude, in units of degrees from the IERS Reference Meridian.
- Values range from -180.0 to +180.0 inclusive, and are based on the WGS 84 coordinate reference system.
metro_code
: number | null- Metro code, representing designated market areas (DMAs) in the United States.
postal_code
: string | null- The postal code associated with the IP address.
- These are available for some IP addresses in Australia, Canada, France, Germany, Italy, Spain, Switzerland, the United Kingdom, and the United States.
- For Canadian postal codes, this is the first 3 characters. For the United Kingdom, this is the first 2-4 characters (outward code). For countries with alphanumeric postal codes, this field is a lowercase transliteration.
proxy_description
: string | null- Client proxy description.
proxy_type
: string | null- Client proxy type.
region
: string | null- ISO 3166-2 country subdivision code.
- For countries with multiple levels of subdivision (for example, nations within the United Kingdom), this variable gives the more specific subdivision.
- This field can be None for countries that do not have ISO country subdivision codes. For example, None is given for IP addresses assigned to the Åland Islands (country code AX, illustrated below).
utc_offset
: number | null;- Time zone offset from coordinated universal time (UTC) for
city
.
- Time zone offset from coordinated universal time (UTC) for
Examples
In this example we return the geolocation details for the provided ip querystring parameter or for the incoming client request if the querystring parameter does not exist.
/// <reference types="@fastly/js-compute" />
import { getGeolocationForIpAddress } from "fastly:geolocation"
async function app(event) {
try {
let ip = new URL(event.request.url).searchParams.get('ip') || event.client.address
let geo = getGeolocationForIpAddress(ip);
return new Response(JSON.stringify(geo), {
headers: {
"Content-Type": "application/json",
},
});
} catch (error) {
console.error(error);
return new Response("Internal Server Error", {
status: 500
});
}
}
addEventListener("fetch", event => event.respondWith(app(event)));