geolocip deleted ; geolocip2->geolocip ; geolocip corrected
This commit is contained in:
parent
da6aa70fdd
commit
a25cf6b6f3
5 changed files with 31 additions and 139 deletions
|
|
@ -1,6 +1,6 @@
|
|||
# -*- coding: utf-8 -*-
|
||||
|
||||
# Copyright(C) 2010 Romain Bignon
|
||||
# Copyright(C) 2010 Julien Veyssier
|
||||
#
|
||||
# This program is free software; you can redistribute it and/or modify
|
||||
# it under the terms of the GNU General Public License as published by
|
||||
|
|
@ -18,10 +18,8 @@
|
|||
from __future__ import with_statement
|
||||
|
||||
from weboob.capabilities.geolocip import ICapGeolocIp, IpLocation
|
||||
from weboob.capabilities.base import NotAvailable
|
||||
from weboob.tools.backend import BaseBackend
|
||||
from weboob.tools.browser import BaseBrowser
|
||||
from weboob.tools.value import ValuesDict, Value
|
||||
|
||||
|
||||
__all__ = ['GeolocIpBackend']
|
||||
|
|
@ -29,58 +27,45 @@ __all__ = ['GeolocIpBackend']
|
|||
|
||||
class GeolocIpBackend(BaseBackend, ICapGeolocIp):
|
||||
NAME = 'geolocip'
|
||||
MAINTAINER = 'Romain Bignon'
|
||||
EMAIL = 'romain@weboob.org'
|
||||
MAINTAINER = 'Julien Veyssier'
|
||||
EMAIL = 'julien.veyssier@aiur.fr'
|
||||
VERSION = '0.4'
|
||||
LICENSE = 'GPLv3'
|
||||
DESCRIPTION = u"IP Adresses geolocalisation with the API of the site www.geolocalise-ip.com "
|
||||
CONFIG = ValuesDict(Value('email', label='Username'),
|
||||
Value('password',label='Password', masked=True))
|
||||
DESCRIPTION = u"IP Adresses geolocalisation with the site www.geolocip.com"
|
||||
BROWSER = BaseBrowser
|
||||
|
||||
def create_default_browser(self):
|
||||
return self.create_browser(self.config['email'], self.config['password'])
|
||||
return self.create_browser()
|
||||
|
||||
def get_location(self, ipaddr):
|
||||
with self.browser:
|
||||
args = {'email': self.config['email'],
|
||||
'pass': self.config['password'],
|
||||
'ip': str(ipaddr)
|
||||
}
|
||||
content = self.browser.readurl(self.browser.buildurl('http://www.geolocalise-ip.com/api.php', **args))
|
||||
tab = {'ville' : NotAvailable ,\
|
||||
'region' : NotAvailable ,\
|
||||
'cp' : NotAvailable ,\
|
||||
'pays' : NotAvailable ,\
|
||||
'lt' : NotAvailable ,\
|
||||
'lg' : NotAvailable ,\
|
||||
'host' : NotAvailable ,\
|
||||
'tld' : NotAvailable ,\
|
||||
'fai' : NotAvailable}
|
||||
|
||||
for line in content.split('&'):
|
||||
if not '=' in line:
|
||||
continue
|
||||
key, value = line.split('=', 1)
|
||||
tab[key] = value
|
||||
|
||||
if 'erreur' in tab and tab['erreur'][0] == '1':
|
||||
raise Exception(tab['erreur'][1:].replace('<p>', '').replace('</p>', '').replace('<br />', '\n')\
|
||||
.strip().decode('iso-8859-1'))
|
||||
content = self.browser.readurl('http://www.geolocip.com/?s[ip]=%s&commit=locate+IP!' % str(ipaddr))
|
||||
|
||||
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)
|
||||
|
||||
if tab['ville'] != NotAvailable:
|
||||
iploc.city = tab['ville'].decode('iso-8859-15')
|
||||
iploc.region = tab['region']
|
||||
iploc.zipcode = tab['cp']
|
||||
iploc.country = tab['pays']
|
||||
iploc.lt = float(tab['lt'])
|
||||
iploc.lg = float(tab['lg'])
|
||||
iploc.host = tab['host']
|
||||
iploc.tld = tab['tld']
|
||||
if 'fai' in tab:
|
||||
iploc.isp = tab['fai']
|
||||
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.isp = NotAvailable
|
||||
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
|
||||
|
|
|
|||
|
|
@ -1,6 +1,6 @@
|
|||
# -*- coding: utf-8 -*-
|
||||
|
||||
# Copyright(C) 2010 Romain Bignon
|
||||
# Copyright(C) 2010 Julien Veyssier
|
||||
#
|
||||
# This program is free software; you can redistribute it and/or modify
|
||||
# it under the terms of the GNU General Public License as published by
|
||||
|
|
|
|||
|
|
@ -1,3 +0,0 @@
|
|||
from .backend import GeolocIp2Backend
|
||||
|
||||
__all__ = ['GeolocIp2Backend']
|
||||
|
|
@ -1,65 +0,0 @@
|
|||
# -*- coding: utf-8 -*-
|
||||
|
||||
# Copyright(C) 2010 Julien Veyssier
|
||||
#
|
||||
# This program is free software; you can redistribute it and/or modify
|
||||
# it under the terms of the GNU General Public License as published by
|
||||
# the Free Software Foundation, version 3 of the License.
|
||||
#
|
||||
# This program 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 General Public License for more details.
|
||||
#
|
||||
# You should have received a copy of the GNU General Public License
|
||||
# along with this program; if not, write to the Free Software
|
||||
# Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA.
|
||||
|
||||
from __future__ import with_statement
|
||||
|
||||
from weboob.capabilities.geolocip import ICapGeolocIp, IpLocation
|
||||
from weboob.tools.backend import BaseBackend
|
||||
from weboob.tools.browser import BaseBrowser
|
||||
|
||||
|
||||
__all__ = ['GeolocIp2Backend']
|
||||
|
||||
|
||||
class GeolocIp2Backend(BaseBackend, ICapGeolocIp):
|
||||
NAME = 'geolocip2'
|
||||
MAINTAINER = 'Julien Veyssier'
|
||||
EMAIL = 'julien.veyssier@aiur.fr'
|
||||
VERSION = '0.4'
|
||||
LICENSE = 'GPLv3'
|
||||
DESCRIPTION = u"IP Adresses geolocalisation with the site www.geolocip.com"
|
||||
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))
|
||||
|
||||
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']
|
||||
iploc.lt = float(tab['Latitude'])
|
||||
iploc.lg = float(tab['Longitude'])
|
||||
#iploc.host = 'NA'
|
||||
#iploc.tld = 'NA'
|
||||
#iploc.isp = 'NA'
|
||||
|
||||
return iploc
|
||||
|
|
@ -1,25 +0,0 @@
|
|||
# -*- coding: utf-8 -*-
|
||||
|
||||
# Copyright(C) 2010 Julien Veyssier
|
||||
#
|
||||
# This program is free software; you can redistribute it and/or modify
|
||||
# it under the terms of the GNU General Public License as published by
|
||||
# the Free Software Foundation, version 3 of the License.
|
||||
#
|
||||
# This program 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 General Public License for more details.
|
||||
#
|
||||
# You should have received a copy of the GNU General Public License
|
||||
# along with this program; if not, write to the Free Software
|
||||
# Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA.
|
||||
|
||||
|
||||
from weboob.tools.test import BackendTest
|
||||
|
||||
class GeolocIP2Test(BackendTest):
|
||||
BACKEND = 'geolocip2'
|
||||
|
||||
def test_geolocip2(self):
|
||||
self.backend.get_location('88.198.11.130')
|
||||
Loading…
Add table
Add a link
Reference in a new issue