support dispobank
This commit is contained in:
parent
6a5d3b259e
commit
3ec1cac9e3
3 changed files with 36 additions and 15 deletions
|
|
@ -38,12 +38,15 @@ class BredBackend(BaseBackend, ICapBank):
|
||||||
LICENSE = 'AGPLv3+'
|
LICENSE = 'AGPLv3+'
|
||||||
CONFIG = BackendConfig(ValueBackendPassword('login', label='Identifiant', masked=False),
|
CONFIG = BackendConfig(ValueBackendPassword('login', label='Identifiant', masked=False),
|
||||||
ValueBackendPassword('password', label='Mot de passe'),
|
ValueBackendPassword('password', label='Mot de passe'),
|
||||||
|
Value('website', label="Site d'accès", default='bred',
|
||||||
|
choices={'bred': 'BRED', 'dispobank': 'DispoBank'}),
|
||||||
Value('accnum', label='Account number to force (optional)', default='', masked=False)
|
Value('accnum', label='Account number to force (optional)', default='', masked=False)
|
||||||
)
|
)
|
||||||
BROWSER = BredBrowser
|
BROWSER = BredBrowser
|
||||||
|
|
||||||
def create_default_browser(self):
|
def create_default_browser(self):
|
||||||
return self.create_browser(self.config['accnum'].get(),
|
return self.create_browser(self.config['website'].get(),
|
||||||
|
self.config['accnum'].get(),
|
||||||
self.config['login'].get(),
|
self.config['login'].get(),
|
||||||
self.config['password'].get())
|
self.config['password'].get())
|
||||||
|
|
||||||
|
|
|
||||||
|
|
@ -31,18 +31,29 @@ __all__ = ['BredBrowser']
|
||||||
class BredBrowser(BaseBrowser):
|
class BredBrowser(BaseBrowser):
|
||||||
PROTOCOL = 'https'
|
PROTOCOL = 'https'
|
||||||
DOMAIN = 'www.bred.fr'
|
DOMAIN = 'www.bred.fr'
|
||||||
CERTHASH = '375f1fed165d34aacaaf71674ab14ca6c1b38404cf748278714fde3c58385ff0'
|
CERTHASH = ['375f1fed165d34aacaaf71674ab14ca6c1b38404cf748278714fde3c58385ff0', '0853a056453b56aea6a29085ef3f3721b18db2052aa8e84220720d44e0eb22af']
|
||||||
ENCODING = 'iso-8859-15'
|
ENCODING = 'iso-8859-15'
|
||||||
PAGES = {'https://www.bred.fr/mylittleform.*': LoginPage,
|
PAGES = {'https://www.\w+.fr/mylittleform.*': LoginPage,
|
||||||
'https://www.bred.fr/Andromede/MainAuth.*': LoginResultPage,
|
'https://www.\w+.fr/Andromede/MainAuth.*': LoginResultPage,
|
||||||
'https://www.bred.fr/Andromede/Main': AccountsPage,
|
'https://www.\w+.fr/Andromede/Main': AccountsPage,
|
||||||
'https://www.bred.fr/Andromede/Ecriture': TransactionsPage,
|
'https://www.\w+.fr/Andromede/Ecriture': TransactionsPage,
|
||||||
'https://www.bred.fr/Andromede/applications/index.jsp': EmptyPage,
|
'https://www.\w+.fr/Andromede/applications/index.jsp': EmptyPage,
|
||||||
'https://www.bred.fr/': EmptyPage,
|
'https://www.bred.fr/': EmptyPage,
|
||||||
|
'https://www.dispobank.fr/?': LoginPage,
|
||||||
}
|
}
|
||||||
|
|
||||||
def __init__(self, accnum, *args, **kwargs):
|
URLS = {'bred': {'home': 'https://www.bred.fr/Andromede/Main',
|
||||||
|
'login': 'https://www.bred.fr/mylittleform?type=1',
|
||||||
|
},
|
||||||
|
'dispobank': {'home': 'https://www.dispobank.fr',
|
||||||
|
'login': 'https://www.dispobank.fr',
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
def __init__(self, website, accnum, *args, **kwargs):
|
||||||
self.accnum = accnum.zfill(11)
|
self.accnum = accnum.zfill(11)
|
||||||
|
self.DOMAIN = 'www.%s.fr' % website
|
||||||
|
self.website = website
|
||||||
BaseBrowser.__init__(self, *args, **kwargs)
|
BaseBrowser.__init__(self, *args, **kwargs)
|
||||||
|
|
||||||
def is_logged(self):
|
def is_logged(self):
|
||||||
|
|
@ -52,14 +63,14 @@ class BredBrowser(BaseBrowser):
|
||||||
if not self.is_logged():
|
if not self.is_logged():
|
||||||
self.login()
|
self.login()
|
||||||
else:
|
else:
|
||||||
self.location('https://www.bred.fr/Andromede/Main')
|
self.location(self.URLS[self.website]['home'])
|
||||||
|
|
||||||
def login(self):
|
def login(self):
|
||||||
assert isinstance(self.username, basestring)
|
assert isinstance(self.username, basestring)
|
||||||
assert isinstance(self.password, basestring)
|
assert isinstance(self.password, basestring)
|
||||||
|
|
||||||
if not self.is_on_page(LoginPage):
|
if not self.is_on_page(LoginPage):
|
||||||
self.location('https://www.bred.fr/mylittleform?type=1', no_login=True)
|
self.location(self.URLS[self.website]['login'], no_login=True)
|
||||||
|
|
||||||
self.page.login(self.username, self.password)
|
self.page.login(self.username, self.password)
|
||||||
|
|
||||||
|
|
@ -74,7 +85,7 @@ class BredBrowser(BaseBrowser):
|
||||||
|
|
||||||
def get_accounts_list(self):
|
def get_accounts_list(self):
|
||||||
if not self.is_on_page(AccountsPage):
|
if not self.is_on_page(AccountsPage):
|
||||||
self.location('https://www.bred.fr/Andromede/Main')
|
self.location('https://www.%s.fr/Andromede/Main' % self.website)
|
||||||
return self.page.get_list()
|
return self.page.get_list()
|
||||||
|
|
||||||
def get_account(self, id):
|
def get_account(self, id):
|
||||||
|
|
@ -99,7 +110,7 @@ class BredBrowser(BaseBrowser):
|
||||||
'monnaie': 'EUR',
|
'monnaie': 'EUR',
|
||||||
'index_hist': 4
|
'index_hist': 4
|
||||||
}
|
}
|
||||||
self.location('https://www.bred.fr/Andromede/Ecriture', urllib.urlencode(data))
|
self.location('https://www.%s.fr/Andromede/Ecriture' % self.website, urllib.urlencode(data))
|
||||||
|
|
||||||
assert self.is_on_page(TransactionsPage)
|
assert self.is_on_page(TransactionsPage)
|
||||||
return self.page.get_history(is_coming)
|
return self.page.get_history(is_coming)
|
||||||
|
|
|
||||||
|
|
@ -19,6 +19,9 @@
|
||||||
|
|
||||||
|
|
||||||
from mechanize import FormNotFoundError
|
from mechanize import FormNotFoundError
|
||||||
|
from weboob.tools.mech import ClientForm
|
||||||
|
ControlNotFoundError = ClientForm.ControlNotFoundError
|
||||||
|
|
||||||
from decimal import Decimal, InvalidOperation
|
from decimal import Decimal, InvalidOperation
|
||||||
import re
|
import re
|
||||||
|
|
||||||
|
|
@ -35,8 +38,12 @@ __all__ = ['LoginPage', 'LoginResultPage', 'AccountsPage', 'TransactionsPage', '
|
||||||
class LoginPage(BasePage):
|
class LoginPage(BasePage):
|
||||||
def login(self, login, passwd):
|
def login(self, login, passwd):
|
||||||
self.browser.select_form(name='authen')
|
self.browser.select_form(name='authen')
|
||||||
self.browser['id'] = login.encode(self.browser.ENCODING)
|
try:
|
||||||
self.browser['pass'] = passwd.encode(self.browser.ENCODING)
|
self.browser['id'] = login.encode(self.browser.ENCODING)
|
||||||
|
self.browser['pass'] = passwd.encode(self.browser.ENCODING)
|
||||||
|
except ControlNotFoundError:
|
||||||
|
self.browser.controls.append(ClientForm.TextControl('text', 'id', {'value': login.encode(self.browser.ENCODING)}))
|
||||||
|
self.browser.controls.append(ClientForm.TextControl('text', 'pass', {'value': passwd.encode(self.browser.ENCODING)}))
|
||||||
self.browser.submit(nologin=True)
|
self.browser.submit(nologin=True)
|
||||||
|
|
||||||
|
|
||||||
|
|
|
||||||
Loading…
Add table
Add a link
Reference in a new issue