forked from TommyLau/docker-ocserv
-
Notifications
You must be signed in to change notification settings - Fork 0
/
route.py
executable file
·81 lines (63 loc) · 2.68 KB
/
route.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
72
73
74
75
76
77
78
79
80
81
#!/usr/bin/env python
# -*- coding: utf-8 -*-
import glob
import socket
import xml.etree.ElementTree
import urllib2
def get_netmask(mask):
bits = 0
for i in xrange(32 - mask, 32):
bits |= (1 << i)
return "%d.%d.%d.%d" % ((bits & 0xff000000) >> 24, (bits & 0xff0000) >> 16, (bits & 0xff00) >> 8, (bits & 0xff))
def get_decimal_ip(ip):
ip_split = ip.split('.')
ip_decimal = 0
for i in ip_split:
ip_decimal += int(i)
ip_decimal <<= 8
ip_decimal >>= 8
return ip_decimal
def query_cidr(ip):
url = "http://whois.arin.net/rest/nets;q=%s?showDetails=true&showARIN=false&ext=netref2" % ip
f = urllib2.urlopen(url)
root = xml.etree.ElementTree.fromstring(f.read())
net_block = root.find("{http://www.arin.net/whoisrws/core/v1}net").find(
"{http://www.arin.net/whoisrws/core/v1}netBlocks").find("{http://www.arin.net/whoisrws/core/v1}netBlock")
start_address = net_block.find("{http://www.arin.net/whoisrws/core/v1}startAddress").text
cidr_length = int(net_block.find("{http://www.arin.net/whoisrws/core/v1}cidrLength").text)
return start_address, get_netmask(cidr_length)
if __name__ == "__main__":
route_table = {}
# Read the old route tables from file
with open("route.txt", "r") as f:
for line in f:
l = line.strip()
if len(l) != 0 and l[0] != '#':
addr, mask = l.split('=')[1].strip().split('/')
route_table[get_decimal_ip(addr)] = (addr, mask)
for fn in glob.glob("domain-*.txt"):
print("Read from file [%s]" % fn)
with open(fn, "r") as f:
for line in f:
domain = line.strip()
if len(domain) != 0 and domain[0] != '#':
print(" Processing domain [%s] " % domain),
ip = socket.gethostbyname(domain)
print("IP: %s" % ip),
decimal_ip = get_decimal_ip(ip)
exist = False
for t in route_table:
if (get_decimal_ip(route_table[t][1]) & decimal_ip) == t:
exist = True
break
if exist:
print "exist, skip . . ."
else:
addr, mask = query_cidr(ip)
route_table[get_decimal_ip(addr)] = (addr, mask)
print("CIDR: %s/%s" % (addr, mask))
tables = sorted(route_table.items())
with open("route.txt", "w") as f:
for route in tables:
print("route = %s/%s" % (route[1][0], route[1][1]))
f.write("route = %s/%s\n" % (route[1][0], route[1][1]))