aws-edge-locations
v0.6.1
Published
AWS CloudFront edge location data
Downloads
340
Readme
aws-edge-locations
List of AWS CloudFront Edge Location code prefixes including latitude/longitude information, usable via a lookup mechanism.
Data
If you're here for the plain data, have a look at
- List of AWS CloudFront Edge Locations (as CSV)
- List of AWS CloudFront Edge Locations (as JSON)
- List of AWS CloudFront Edge Locations (as Parquet)
Installation
To install, you can do the following:
$ npm i --save aws-edge-locations
Usage
Node
This package can be used to lookup the AWS CloudFront Edge Locations via the three character prefix (the first three characters of the location
(e.g. IAD12
) field in the CloudFront logs).
const AWSEdgeLocations = require('aws-edge-locations').default;
// Or
// import AWSEdgeLocations from 'aws-edge-locations';
const el = new AWSEdgeLocations();
const location = el.lookup('IAD12'.substr(0,3)); // Use only the first three characters!
/* returns
{
"city": "Washington",
"country": "United States",
"countryCode": "US",
"latitude": 38.94449997,
"longitude": -77.45580292,
"pricingRegion": "United States, Mexico, & Canada"
}
*/
const invalid = el.lookup('FOO'); // returns false
// Get edge location count
const locationCount = el.getLocationCount(); // returns the current number of locations
Browser
This package is published as an UMD module, and can be used in the browser directly from unpkg.
<html>
<head>
<script src="https://unpkg.com/aws-edge-locations"></script>
</head>
<body>
<script>
// Using the global variable
document.write('There are ' + awsEdgeLocations.getLocationCount() + ' edge locations');
</script>
</body>
</html>
Local data generation
To prepare the data regeneration, please run npm run download-airports && npm run filter-airports
.
The npm run generate
script will regenerate the csv
, json
and parquet
versions of the AWS CloudFront Edge Location list in the data
folder.
It does this by extracting the information from the Amazon CloudFront Key Features page, cleaning and unifiying it, and merging it with airport data (the first three characters of the location
field are IATA airport codes) to also get the latitude/longitude information.
Also, there are some manual overrides when it wasn't possible to automatically determine the correct IATA code from the city names.
Running npm run build
will transpile the TypeScript code in the src
directory and save it in the dist
directory.