bred: ability to select accounts
This commit is contained in:
parent
f46c2c3e71
commit
fe6d99c51a
3 changed files with 32 additions and 4 deletions
|
|
@ -21,7 +21,7 @@
|
|||
|
||||
from weboob.capabilities.bank import ICapBank, AccountNotFound
|
||||
from weboob.tools.backend import BaseBackend, BackendConfig
|
||||
from weboob.tools.value import ValueBackendPassword
|
||||
from weboob.tools.value import ValueBackendPassword, Value
|
||||
|
||||
from .browser import BredBrowser
|
||||
|
||||
|
|
@ -37,11 +37,15 @@ class BredBackend(BaseBackend, ICapBank):
|
|||
DESCRIPTION = u'BRED French bank website'
|
||||
LICENSE = 'AGPLv3+'
|
||||
CONFIG = BackendConfig(ValueBackendPassword('login', label='Account ID', masked=False),
|
||||
ValueBackendPassword('password', label='Password of account'))
|
||||
ValueBackendPassword('password', label='Password of account'),
|
||||
Value('accnum', label='Account number to force (optional)', default='', masked=False)
|
||||
)
|
||||
BROWSER = BredBrowser
|
||||
|
||||
def create_default_browser(self):
|
||||
return self.create_browser(self.config['login'].get(), self.config['password'].get())
|
||||
return self.create_browser(self.config['accnum'].get(),
|
||||
self.config['login'].get(),
|
||||
self.config['password'].get())
|
||||
|
||||
def iter_accounts(self):
|
||||
with self.browser:
|
||||
|
|
|
|||
|
|
@ -41,6 +41,10 @@ class BredBrowser(BaseBrowser):
|
|||
'https://www.bred.fr/': EmptyPage,
|
||||
}
|
||||
|
||||
def __init__(self, accnum, *args, **kwargs):
|
||||
self.accnum = accnum.zfill(11)
|
||||
BaseBrowser.__init__(self, *args, **kwargs)
|
||||
|
||||
def is_logged(self):
|
||||
return self.page is not None and not self.is_on_page(LoginPage)
|
||||
|
||||
|
|
|
|||
|
|
@ -55,7 +55,27 @@ class LoginResultPage(BasePage):
|
|||
pass
|
||||
else:
|
||||
self.browser.set_all_readonly(False)
|
||||
self.browser['typeCompte'] = 'P'
|
||||
accounts = {}
|
||||
for tr in self.document.getroot().cssselect('table.compteTable tbody tr'):
|
||||
attr = tr.xpath('.//a')[0].attrib.get('onclick', '')
|
||||
m = re.search("value = '(\w+)';checkAndSubmit\('\w+','(\w+)','(\w+)'\)", attr)
|
||||
if m:
|
||||
typeCompte = m.group(1)
|
||||
tagName = m.group(2)
|
||||
value = self.document.xpath('//input[@id="%s%s"]' % (m.group(2), m.group(3)))[0].attrib['value']
|
||||
accounts[value] = (typeCompte, tagName)
|
||||
|
||||
try:
|
||||
typeCompte, tagName = accounts[self.browser.accnum]
|
||||
value = self.browser.accnum
|
||||
except KeyError:
|
||||
if self.browser.accnum != '00000000000':
|
||||
self.logger.warning(u'Unable to find account "%s". Available ones: %s' % (self.browser.accnum, ', '.join(accounts.keys())))
|
||||
elif len(accounts) > 1:
|
||||
self.logger.warning('There are several accounts, please use "accnum" backend parameter to force the one to use')
|
||||
value, (typeCompte, tagName) = accounts.popitem()
|
||||
self.browser['typeCompte'] = typeCompte
|
||||
self.browser[tagName] = [value]
|
||||
self.browser.submit()
|
||||
|
||||
|
||||
|
|
|
|||
Loading…
Add table
Add a link
Reference in a new issue