weboob-devel/modules/regionsjob/browser.py
2014-10-23 10:13:13 +02:00

65 lines
2 KiB
Python

# -*- coding: utf-8 -*-
# Copyright(C) 2014 Bezleputh
#
# 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/>.
import urllib
from weboob.browser import PagesBrowser, URL
from .pages import SearchPage, AdvertPage
__all__ = ['RegionsjobBrowser']
class RegionsjobBrowser(PagesBrowser):
search_page = URL('emplois/recherche.html\?.*', SearchPage)
advert_page = URL('emplois/(?P<_id>.*)\.html', AdvertPage)
def __init__(self, website, *args, **kwargs):
self.BASEURL = 'http://%s' % website
PagesBrowser.__init__(self, *args, **kwargs)
def search_job(self, pattern='', fonction='', secteur='', contract='',
experience='', qualification='', enterprise_type=''):
params = {'k': urllib.quote_plus(pattern.encode('utf-8'))}
if fonction:
params['f'] = fonction
if qualification:
params['q'] = qualification
if contract:
params['c'] = contract
if experience:
params['e'] = experience
if secteur:
params['s'] = secteur
if enterprise_type:
params['et'] = enterprise_type
return self.search_page.go(params=params).iter_job_adverts(domain=self.BASEURL)
def get_job_advert(self, _id, advert):
splitted_id = _id.split('#')
self.BASEURL = 'http://www.%s.com' % splitted_id[0]
return self.advert_page.go(_id=splitted_id[1]).get_job_advert(obj=advert)