Добавляет IP-диапазоны Google (#1)

Co-authored-by: Maxim Slipenko <no-reply@maxim.slipenko.com>
Reviewed-on: #1
This commit is contained in:
Maxim Slipenko 2022-09-16 15:15:04 +00:00
parent f6d19ba5b4
commit b748fb1c96
9 changed files with 92 additions and 35 deletions

View File

@ -32,7 +32,6 @@ grafana.com
# #
# NTP сервера Google # NTP сервера Google
# #
time.google.com
time1.google.com time1.google.com
time2.google.com time2.google.com
time3.google.com time3.google.com
@ -47,3 +46,6 @@ chess.com
# developers.google.com # developers.google.com
# #
developers.google.com developers.google.com
googleapis.com
firebase.google.com

6
google_ranges.txt Normal file
View File

@ -0,0 +1,6 @@
34.64.0.0/10
35.240.0.0/13
104.196.0.0/14
216.239.32.0/19
173.194.0.0/16
64.233.160.0/19

19
ips.txt
View File

@ -1,26 +1,13 @@
192.229.221.58/32 # us.download.nvidia.com 192.229.221.58/32 # us.download.nvidia.com
34.120.25.175/32 # habitica.com
104.198.14.52/32 # docs.nestjs.com, nestjs.com
35.244.248.76/32 # stackshare.io
172.65.251.78/32 # gitlab.com 172.65.251.78/32 # gitlab.com
34.120.177.193/32 # grafana.com
216.239.35.0/32 # time.google.com, time1.google.com
216.239.35.4/32 # time2.google.com
216.239.35.8/32 # time3.google.com
216.239.35.12/32 # time4.google.com
34.117.44.137/32 # chess.com
142.251.1.101/32 # developers.google.com
35.190.247.0/24 # google (spf) 35.190.247.0/24 # google (spf)
64.233.160.0/19 # google (spf)
66.102.0.0/20 # google (spf) 66.102.0.0/20 # google (spf)
66.249.80.0/20 # google (spf) 66.249.80.0/20 # google (spf)
72.14.192.0/18 # google (spf) 72.14.192.0/18 # google (spf)
74.125.0.0/16 # google (spf) 74.125.0.0/16 # google (spf)
108.177.8.0/21 # google (spf) 108.177.8.0/21 # google (spf)
173.194.0.0/16 # google (spf)
209.85.128.0/17 # google (spf) 209.85.128.0/17 # google (spf)
216.58.192.0/19 # google (spf) 216.58.192.0/19 # google (spf)
216.239.32.0/19 # google (spf)
172.217.0.0/19 # google (spf) 172.217.0.0/19 # google (spf)
172.217.32.0/20 # google (spf) 172.217.32.0/20 # google (spf)
172.217.128.0/19 # google (spf) 172.217.128.0/19 # google (spf)
@ -31,3 +18,9 @@
108.177.96.0/19 # google (spf) 108.177.96.0/19 # google (spf)
35.191.0.0/16 # google (spf) 35.191.0.0/16 # google (spf)
130.211.0.0/22 # google (spf) 130.211.0.0/22 # google (spf)
34.64.0.0/10 # google_range :: habitica.com (34.120.25.175/32), grafana.com (34.120.177.193/32), chess.com (34.117.44.137/32)
104.196.0.0/14 # google_range :: docs.nestjs.com, nestjs.com (104.198.14.52/32)
35.240.0.0/13 # google_range :: stackshare.io (35.244.248.76/32)
216.239.32.0/19 # google_range :: time1.google.com (216.239.35.0/32), time2.google.com (216.239.35.4/32), time3.google.com (216.239.35.8/32), time4.google.com (216.239.35.12/32), google (spf) (216.239.32.0/19)
64.233.160.0/19 # google_range :: developers.google.com (64.233.161.138/32), firebase.google.com (64.233.164.100/32), google (spf) (64.233.160.0/19)
173.194.0.0/16 # google_range :: googleapis.com (173.194.220.105/32), google (spf) (173.194.0.0/16)

19
is_google_subnet.py Normal file
View File

@ -0,0 +1,19 @@
import ipaddress
import requests
import json
x = input()
res = requests.get('https://www.gstatic.com/ipranges/goog.json')
response = json.loads(res.text)
ipv4Prefix = [x['ipv4Prefix'] for x in filter(lambda x: 'ipv4Prefix' in x, response["prefixes"])]
for prefix in ipv4Prefix:
isInPrefix = ipaddress.ip_address(x) in ipaddress.ip_network(prefix)
if isInPrefix:
print(x, 'is subnet of', prefix)
exit()
print('not found')

View File

@ -5,8 +5,7 @@ from utils import prettyprint
ips = [] ips = []
dict = defaultdict(list) dict = defaultdict(list)
def main(): def main(file_data: list):
with open('ips.txt', 'w') as out:
for line in open('domains.txt'): for line in open('domains.txt'):
l = line.strip() l = line.strip()
@ -18,4 +17,6 @@ def main():
ips = list(dict.keys()) ips = list(dict.keys())
for ip in ips: for ip in ips:
out.write(prettyprint(ip, ', '.join(dict[ip])) + '\n') file_data.append(prettyprint(ip, ', '.join(dict[ip])) + '\n')
return file_data

View File

@ -24,9 +24,11 @@ def resolve_by_spf(domain):
return list(dict.fromkeys(result)) return list(dict.fromkeys(result))
def main(): def main(file_data: list):
ips = resolve_by_spf("_spf.google.com") ips = resolve_by_spf("_spf.google.com")
with open('ips.txt', 'a') as out:
for ip in ips: for ip in ips:
out.write(prettyprint(ip, 'google (spf)') + '\n') file_data.append(prettyprint(ip, 'google (spf)') + '\n')
return file_data

View File

@ -0,0 +1,34 @@
from collections import defaultdict
from utils import prettyprint
import ipaddress
new_ips_data = defaultdict(list)
cloud_ranges_file = open("google_ranges.txt", "r")
cloud_ranges = [x.strip() for x in cloud_ranges_file.readlines()]
def process_list(item: str):
l = item.strip()
if l.startswith('#') or l == '':
return True
[range, comment] = [x.strip() for x in l.split('#')]
for cloud_range in cloud_ranges:
if ipaddress.ip_network(range).subnet_of(ipaddress.ip_network(cloud_range)):
new_ips_data[cloud_range].append(f'{comment} ({range})')
return False
return True
def main(file_data: list[str]):
file_data = list(filter(process_list, file_data))
ips = list(new_ips_data.keys())
for ip in ips:
file_data.append(prettyprint(ip, 'google_range :: ' + ', '.join(new_ips_data[ip])) + '\n')
return file_data

View File

@ -1,7 +1,5 @@
def main(): def main(file_data: list[str]):
inp = open('ips.txt', 'r') uniqlines = list(dict.fromkeys(file_data))
uniqlines = list(dict.fromkeys(inp.readlines()))
inp.close()
out = open('ips.txt', 'w') out = open('ips.txt', 'w')
out.writelines(uniqlines) out.writelines(uniqlines)
out.truncate(out.tell()-1) out.truncate(out.tell()-1)

View File

@ -10,9 +10,11 @@ scripts = glob.glob(f"./{RUNNER_FOLDER}/*.py")
scripts.sort() scripts.sort()
modules = [os.path.basename(x)[:-3] for x in scripts] modules = [os.path.basename(x)[:-3] for x in scripts]
file_data = []
for m in modules: for m in modules:
runner = importlib.import_module('.' + m, package=RUNNER_FOLDER) runner = importlib.import_module('.' + m, package=RUNNER_FOLDER)
runner.main() file_data = runner.main(file_data)
''' '''
for script in scripts: for script in scripts: