convert to browser2

This commit is contained in:
Romain Bignon 2014-03-22 16:06:13 +01:00
commit 014234576e
3 changed files with 61 additions and 81 deletions

View file

@ -18,7 +18,8 @@
# along with weboob. If not, see <http://www.gnu.org/licenses/>.
from weboob.tools.browser import BaseBrowser, BrowserIncorrectPassword
from weboob.tools.browser2 import LoginBrowser, URL, need_login
from weboob.tools.browser import BrowserIncorrectPassword
from .pages import LoginPage, AccountsPage
@ -26,58 +27,40 @@ from .pages import LoginPage, AccountsPage
__all__ = ['AlloRestoBrowser']
class AlloRestoBrowser(BaseBrowser):
DOMAIN = 'www.alloresto.fr'
PROTOCOL = 'http'
ENCODING = 'utf-8'
PAGES = {'http://www.alloresto.fr/identification-requise.*': LoginPage,
'http://www.alloresto.fr/chez-moi/releve-compte-miams': AccountsPage,
}
class AlloRestoBrowser(LoginBrowser):
BASEURL = 'http://www.alloresto.fr'
def is_logged(self):
return self.page is not None and not self.is_on_page(LoginPage)
login = URL('/identification-requise.*', LoginPage)
accounts = URL('/chez-moi/releve-compte-miams', AccountsPage)
def home(self):
self.go_on_accounts_list()
def login(self):
def do_login(self):
assert isinstance(self.username, basestring)
assert isinstance(self.password, basestring)
if not self.is_on_page(LoginPage):
self.location('http://www.alloresto.fr/identification-requise', no_login=True)
self.accounts.stay_or_go()
self.page.login(self.username, self.password)
if not self.is_logged():
if self.login.is_here():
raise BrowserIncorrectPassword()
def go_on_accounts_list(self):
self.location('http://www.alloresto.fr/chez-moi/releve-compte-miams')
@need_login
def get_accounts_list(self):
if not self.is_on_page(AccountsPage):
self.go_on_accounts_list()
return self.page.get_list()
return self.accounts.stay_or_go().iter_accounts()
@need_login
def get_account(self, id):
assert isinstance(id, basestring)
l = self.get_accounts_list()
for a in l:
for a in self.get_accounts_list():
if a.id == id:
return a
return None
@need_login
def get_history(self, account):
if not self.is_on_page(AccountsPage):
self.go_on_accounts_list()
return self.page.get_transactions()
return self.accounts.stay_or_go().get_transactions(type='consommable')
@need_login
def get_coming(self, account):
if not self.is_on_page(AccountsPage):
self.go_on_accounts_list()
return self.page.get_transactions('acquisition')
return self.accounts.stay_or_go().get_transactions(type='acquisition')