[leboncoin] add regions support

This commit is contained in:
Alexandre Morignot 2014-12-09 17:08:23 +01:00 committed by Romain Bignon
commit 9d2b12c531
2 changed files with 42 additions and 5 deletions

View file

@ -25,8 +25,8 @@ from .pages import CityListPage, HousingListPage, HousingPage
class LeboncoinBrowser(PagesBrowser):
BASEURL = 'http://www.leboncoin.fr'
city = URL('ajax/location_list.html\?city=(?P<city>.*)&zipcode=(?P<zip>.*)', CityListPage)
search = URL('(?P<type>.*)/offres/ile_de_france/occasions/\?ps=(?P<ps>.*)&pe=(?P<pe>.*)&ros=(?P<ros>.*)&location=(?P<location>.*)&sqs=(?P<sqs>.*)&sqe=(?P<sqe>.*)&ret=(?P<ret>.*)&f=(?P<advert_type>.*)',
'(?P<_type>.*)/offres/ile_de_france/occasions.*?',
search = URL('(?P<type>.*)/offres/(?P<region>.*)/occasions/\?ps=(?P<ps>.*)&pe=(?P<pe>.*)&ros=(?P<ros>.*)&location=(?P<location>.*)&sqs=(?P<sqs>.*)&sqe=(?P<sqe>.*)&ret=(?P<ret>.*)&f=(?P<advert_type>.*)',
'(?P<_type>.*)/offres/(?P<_region>.*)/occasions.*?',
HousingListPage)
housing = URL('ventes_immobilieres/(?P<_id>.*).htm', HousingPage)
@ -36,6 +36,10 @@ class LeboncoinBrowser(PagesBrowser):
Query.HOUSE_TYPES.PARKING: '4',
Query.HOUSE_TYPES.OTHER: '5'}
def __init__(self, region, *args, **kwargs):
super(LeboncoinBrowser, self).__init__(*args, **kwargs)
self.region = region
def get_cities(self, pattern):
city = ''
zip_code = ''
@ -48,7 +52,8 @@ class LeboncoinBrowser(PagesBrowser):
def search_housings(self, query, advert_type):
type, cities, nb_rooms, area_min, area_max, cost_min, cost_max, ret = self.decode_query(query)
return self.search.go(location=cities,
return self.search.go(region=self.region,
location=cities,
ros=nb_rooms,
sqs=area_min,
sqe=area_max,
@ -81,7 +86,7 @@ class LeboncoinBrowser(PagesBrowser):
if query.type == Query.TYPE_RENT:
_type = 'locations'
self.search.go(_type=_type)
self.search.go(_type=_type, _region=self.region)
nb_rooms = '' if not query.nb_rooms else self.page.get_rooms_min(query.nb_rooms)
area_min = '' if not query.area_min else self.page.get_area_min(query.area_min)

View file

@ -38,7 +38,39 @@ class LeboncoinModule(Module, CapHousing):
BROWSER = LeboncoinBrowser
CONFIG = BackendConfig(Value('advert_type', label='Advert type',
choices={'c': 'Agency', 'p': 'Owner', 'a': 'All'}, default='a'))
choices={'c': 'Agency', 'p': 'Owner', 'a': 'All'}, default='a'),
Value('region', label='Region',
choices=['alsace',
'aquitaine',
'auvergne',
'basse_normandie',
'bourgogne',
'bretagne',
'centre',
'champagne_ardenne',
'corse',
'franche_comte',
'haute_normandie',
'ile_de_france',
'languedoc_roussillon',
'limousin',
'lorraine',
'midi_pyrenees',
'nord_pas_de_calais',
'pays_de_la_loire',
'picardie',
'poitou_chanrentes',
'provence_alpes_cote_d_azur',
'rhone_alpes',
'guadeloupe',
'martinique',
'guyane',
'reunion']))
def create_default_browser(self):
region = self.config['region'].get()
return self.create_browser(region)
def get_housing(self, _id):
return self.browser.get_housing(_id)