commit 0daffadb44d61fcf3eb31f7e7192cbbc46f52c33
Author: Arturo Filastò <art(a)fuffa.org>
Date: Thu Feb 20 12:02:48 2014 +0000
Make GeoIP AS and GeoIP City soft dependencies.
Allows ooniprobe to report back the country of the probe even if no GeoIP ASN
and City database is present.
---
ooni/geoip.py | 35 ++++++++++++++++++-----------------
ooni/nettest.py | 28 +++++++++++-----------------
2 files changed, 29 insertions(+), 34 deletions(-)
diff --git a/ooni/geoip.py b/ooni/geoip.py
index a97a6f5..2792126 100644
--- a/ooni/geoip.py
+++ b/ooni/geoip.py
@@ -30,30 +30,31 @@ def IPToLocation(ipaddr):
country_file = os.path.join(config.advanced.geoip_data_dir, 'GeoIP.dat')
asn_file = os.path.join(config.advanced.geoip_data_dir, 'GeoIPASNum.dat')
- location = {'city': None, 'countrycode': None, 'asn': None}
- try:
- city_dat = GeoIP(city_file)
- try:
- location['city'] = city_dat.record_by_addr(ipaddr)['city']
- except TypeError:
- location['city'] = None
+ location = {'city': None, 'countrycode': 'ZZ', 'asn': 'AS0'}
+ try:
country_dat = GeoIP(country_file)
location['countrycode'] = country_dat.country_code_by_addr(ipaddr)
if not location['countrycode']:
location['countrycode'] = 'ZZ'
-
- asn_dat = GeoIP(asn_file)
- try:
- location['asn'] = asn_dat.org_by_addr(ipaddr).split(' ')[0]
- except AttributeError:
- location['asn'] = 'AS0'
-
except IOError:
- log.err("Could not find GeoIP data files. Go into %s "
- "and run make geoip or change the geoip_data_dir "
+ log.err("Could not find GeoIP data file. Go into %s "
+ "and make sure GeoIP.dat is present or change the location "
"in the config file" % config.advanced.geoip_data_dir)
- raise GeoIPDataFilesNotFound
+ try:
+ city_dat = GeoIP(city_file)
+ location['city'] = city_dat.record_by_addr(ipaddr)['city']
+ except:
+ log.err("Could not find the city your IP is from. "
+ "Download the GeoLiteCity.dat file into the geoip_data_dir"
+ " or install geoip-database-contrib.")
+ try:
+ asn_dat = GeoIP(asn_file)
+ location['asn'] = asn_dat.org_by_addr(ipaddr).split(' ')[0]
+ except:
+ log.err("Could not find the ASN for your IP. "
+ "Download the GeoIPASNum.dat file into the geoip_data_dir"
+ " or install geoip-database-contrib.")
return location
diff --git a/ooni/nettest.py b/ooni/nettest.py
index 526de5d..1780953 100644
--- a/ooni/nettest.py
+++ b/ooni/nettest.py
@@ -238,17 +238,19 @@ class NetTestLoader(object):
def testDetails(self):
from ooni import __version__ as software_version
- client_geodata = {}
+ client_geodata = {
+ 'city': None,
+ 'countrycode': 'ZZ',
+ 'asn': 'AS0',
+ 'ip': '127.0.0.1'
+ }
+
if config.probe_ip.address and (config.privacy.includeip or \
config.privacy.includeasn or \
config.privacy.includecountry or \
config.privacy.includecity):
log.msg("We will include some geo data in the report")
- try:
- client_geodata = geoip.IPToLocation(config.probe_ip.address)
- except e.GeoIPDataFilesNotFound:
- log.err("Unable to find the geoip data files")
- client_geodata = {'city': None, 'countrycode': None, 'asn': None}
+ client_geodata = geoip.IPToLocation(config.probe_ip.address)
if config.privacy.includeip:
client_geodata['ip'] = config.probe_ip.address
@@ -257,21 +259,13 @@ class NetTestLoader(object):
# Here we unset all the client geodata if the option to not include then
# has been specified
- if client_geodata and not config.privacy.includeasn:
+ if not config.privacy.includeasn:
client_geodata['asn'] = 'AS0'
- elif 'asn' in client_geodata:
- # XXX this regexp should probably go inside of geodata
- client_geodata['asn'] = client_geodata['asn']
- log.msg("Your AS number is: %s" % client_geodata['asn'])
- else:
- client_geodata['asn'] = None
- if (client_geodata and not config.privacy.includecity) \
- or ('city' not in client_geodata):
+ if not config.privacy.includecity:
client_geodata['city'] = None
- if (client_geodata and not config.privacy.includecountry) \
- or ('countrycode' not in client_geodata):
+ if not config.privacy.includecountry:
client_geodata['countrycode'] = None
input_file_hashes = []