76 lines
2.5 KiB
Python
76 lines
2.5 KiB
Python
# -*- coding: utf-8 -*-
|
|
|
|
# Copyright(C) 2010-2011 Julien Veyssier
|
|
#
|
|
# This file is part of weboob.
|
|
#
|
|
# weboob is free software: you can redistribute it and/or modify
|
|
# it under the terms of the GNU Affero General Public License as published by
|
|
# the Free Software Foundation, either version 3 of the License, or
|
|
# (at your option) any later version.
|
|
#
|
|
# weboob is distributed in the hope that it will be useful,
|
|
# but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
|
# GNU Affero General Public License for more details.
|
|
#
|
|
# You should have received a copy of the GNU Affero General Public License
|
|
# along with weboob. If not, see <http://www.gnu.org/licenses/>.
|
|
|
|
from __future__ import with_statement
|
|
|
|
from weboob.capabilities.geolocip import ICapGeolocIp, IpLocation
|
|
from weboob.tools.backend import BaseBackend
|
|
from weboob.tools.browser import BaseBrowser, BrowserUnavailable
|
|
|
|
|
|
__all__ = ['GeolocIpBackend']
|
|
|
|
|
|
class GeolocIpBackend(BaseBackend, ICapGeolocIp):
|
|
NAME = 'geolocip'
|
|
MAINTAINER = 'Julien Veyssier'
|
|
EMAIL = 'julien.veyssier@aiur.fr'
|
|
VERSION = '0.d'
|
|
LICENSE = 'AGPLv3+'
|
|
DESCRIPTION = u"GeolocIP IP addresses geolocation service"
|
|
BROWSER = BaseBrowser
|
|
|
|
def create_default_browser(self):
|
|
return self.create_browser()
|
|
|
|
def get_location(self, ipaddr):
|
|
with self.browser:
|
|
|
|
content = self.browser.readurl('http://www.geolocip.com/?s[ip]=%s&commit=locate+IP!' % str(ipaddr))
|
|
|
|
if content is None:
|
|
raise BrowserUnavailable()
|
|
|
|
tab = {}
|
|
last_line = ''
|
|
line = ''
|
|
for line in content.split('\n'):
|
|
if len(line.split('<dd>')) > 1:
|
|
key = last_line.split('<dt>')[1].split('</dt>')[0][0:-2]
|
|
value = line.split('<dd>')[1].split('</dd>')[0]
|
|
tab[key] = value
|
|
last_line = line
|
|
iploc = IpLocation(ipaddr)
|
|
iploc.city = tab['City']
|
|
iploc.region = tab['Region']
|
|
iploc.zipcode = tab['Postal code']
|
|
iploc.country = tab['Country name']
|
|
if tab['Latitude'] != '':
|
|
iploc.lt = float(tab['Latitude'])
|
|
else:
|
|
iploc.lt = 0.0
|
|
if tab['Longitude'] != '':
|
|
iploc.lg = float(tab['Longitude'])
|
|
else:
|
|
iploc.lg = 0.0
|
|
#iploc.host = 'NA'
|
|
#iploc.tld = 'NA'
|
|
#iploc.isp = 'NA'
|
|
|
|
return iploc
|