First implementation of champslibres module
This commit is contained in:
parent
642cfbb41c
commit
12c51ba61c
6 changed files with 254 additions and 0 deletions
71
modules/champslibres/pages.py
Normal file
71
modules/champslibres/pages.py
Normal file
|
|
@ -0,0 +1,71 @@
|
|||
# -*- coding: utf-8 -*-
|
||||
|
||||
# Copyright(C) 2012 Florent Fourcot
|
||||
#
|
||||
# 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 datetime import date
|
||||
from weboob.capabilities.library import Book
|
||||
from weboob.tools.browser import BasePage
|
||||
|
||||
|
||||
class SkipPage(BasePage):
|
||||
pass
|
||||
|
||||
|
||||
class HomePage(BasePage):
|
||||
def on_loaded(self):
|
||||
link = self.document.find('//a[@id="patronRSSFeedLinkComponent"]')
|
||||
self.id = link.attrib['href'].split('/')[4]
|
||||
|
||||
def get_id(self):
|
||||
return self.id
|
||||
|
||||
|
||||
def txt2date(s):
|
||||
split = s.split('-')
|
||||
return date(int(split[2]) + 2000, int(split[1]), int(split[0]))
|
||||
|
||||
|
||||
class RentedPage(BasePage):
|
||||
def get_list(self):
|
||||
for tr in self.document.getroot().xpath('//tr[@class="patFuncEntry"]'):
|
||||
id = tr.xpath('td/input')[0].attrib["value"]
|
||||
book = Book(id)
|
||||
bigtitle = tr.xpath('td[@class="patFuncTitle"]/label/a')[0].text
|
||||
book.name = bigtitle.split('/')[0]
|
||||
book.author = bigtitle.split('/')[1]
|
||||
date = tr.xpath('td[@class="patFuncStatus"]')[0].text
|
||||
book.date = txt2date(date.replace('RETOUR', ''))
|
||||
yield book
|
||||
|
||||
|
||||
class HistoryPage(BasePage):
|
||||
pass
|
||||
|
||||
|
||||
class BookedPage(BasePage):
|
||||
# TODO: book some books...
|
||||
pass
|
||||
|
||||
|
||||
class LoginPage(BasePage):
|
||||
def login(self, login, passwd):
|
||||
self.browser.select_form(nr=0)
|
||||
self.browser.form.set_all_readonly(False)
|
||||
self.browser['code'] = login
|
||||
self.browser['pin'] = passwd
|
||||
self.browser.submit()
|
||||
Loading…
Add table
Add a link
Reference in a new issue