-
Notifications
You must be signed in to change notification settings - Fork 3
/
Copy pathaws_ranges_parser.py
71 lines (53 loc) · 1.92 KB
/
aws_ranges_parser.py
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
import logging
import requests
import pandas as pd
from tabulate import tabulate
# Configure logging
logging.basicConfig(level=logging.INFO,
format="%(asctime)s [%(levelname)s] %(message)s",
datefmt="%Y-%m-%d %H:%M:%S")
def download_json_file(url):
try:
response = requests.get(url, verify=False)
response.raise_for_status()
except requests.exceptions.RequestException as err:
logging.error(f"HTTP request failed: {err}")
return None
try:
data = response.json()
except ValueError:
logging.error("Failed to parse JSON")
return None
return data
def process_data(data):
# Extract the 'prefixes' and 'ipv6_prefixes' into separate dataframes
prefixes_df = pd.DataFrame(data['prefixes'])
ipv6_prefixes_df = pd.DataFrame(data['ipv6_prefixes'])
# Combine both into a single DataFrame
combined_df = pd.concat([prefixes_df, ipv6_prefixes_df])
return combined_df
def filter_and_sort(df):
# Filter rows in the London region
london_df = df[df['region'] == 'eu-west-2']
# Filter rows with the AMAZON service
amazon_df = london_df[london_df['service'] == 'AMAZON']
# Sort by the column 'ip_prefix'
amazon_df.sort_values(by=['ip_prefix'], inplace=True)
# Reset the index
amazon_df.reset_index(drop=True, inplace=True)
return amazon_df
def main():
url = "https://ip-ranges.amazonaws.com/ip-ranges.json"
logging.info(f"Downloading JSON file from {url}")
data = download_json_file(url)
if data is None:
logging.error("Failed to download or parse JSON file")
return
logging.info("Processing data")
df = process_data(data)
logging.info("Filtering and sorting data")
final_df = filter_and_sort(df)
# Print the dataframe in a nice format
print(tabulate(final_df, headers='keys', tablefmt='psql'))
if __name__ == "__main__":
main()