[weboob] [PATCH 1/1] modified: weboob/backends/bp/backend.py modified: weboob/backends/bp/browser.py new file: weboob/backends/bp/pages/__init__.py new file: weboob/backends/bp/pages/accounthistory.py new file: weboob/backends/bp/pages/accountlist.py new file: weboob/backends/bp/pages/cookie.py new file: weboob/backends/bp/pages/login.py

Romain Bignon romain at peerfuse.org
Wed Nov 10 18:46:06 CET 2010


Salut,

Tu n'arrives pas à publier sur ton dépôt public ? As-tu lu mon mail concernant
le changement à faire dans .git/config ?

Romain

On 10/Nov - 18:43, Nicolas Duhamel wrote:
>  * Bug #422 BP should use a class derived from BaseBrowser to respect the codeline of Weboob.
> 
>  * N'implante pas encore transfert() ni BrowserIncorrectPassword
> 
> Signed-off-by: Nicolas Duhamel <nicolas at jombi.fr>
> ---
>  weboob/backends/bp/backend.py              |   13 +--
>  weboob/backends/bp/browser.py              |  251 ++++++----------------------
>  weboob/backends/bp/pages/__init__.py       |   23 +++
>  weboob/backends/bp/pages/accounthistory.py |   66 ++++++++
>  weboob/backends/bp/pages/accountlist.py    |   71 ++++++++
>  weboob/backends/bp/pages/cookie.py         |   26 +++
>  weboob/backends/bp/pages/login.py          |   52 ++++++
>  7 files changed, 292 insertions(+), 210 deletions(-)
>  create mode 100644 weboob/backends/bp/pages/__init__.py
>  create mode 100644 weboob/backends/bp/pages/accounthistory.py
>  create mode 100644 weboob/backends/bp/pages/accountlist.py
>  create mode 100644 weboob/backends/bp/pages/cookie.py
>  create mode 100644 weboob/backends/bp/pages/login.py
> 
> diff --git a/weboob/backends/bp/backend.py b/weboob/backends/bp/backend.py
> index 24c81af..858b0f6 100644
> --- a/weboob/backends/bp/backend.py
> +++ b/weboob/backends/bp/backend.py
> @@ -1,8 +1,6 @@
>  # -*- coding: utf-8 -*-
> -#
> -#      backend.py
> -#
> -#      Copyright 2010 nicolas <nicolas at jombi.fr>
> +
> +# Copyright(C) 2010  Nicolas Duhamel
>  #
>  # This program is free software; you can redistribute it and/or modify
>  # it under the terms of the GNU General Public License as published by
> @@ -52,10 +50,3 @@ class BPBackend(BaseBackend, ICapBank):
>          for history in self.browser.get_history(account):
>              yield history
>  
> -    def transfer(self, id_from, id_to, amount, reason=None):
> -        from_account = self.get_account(id_from)
> -        to_account = self.get_account(id_to)
> -
> -        #TODO: retourner le numero du virement
> -        #TODO: support the 'reason' parameter
> -        return self.browser.make_transfer(from_account, to_account, amount)
> diff --git a/weboob/backends/bp/browser.py b/weboob/backends/bp/browser.py
> index 6670107..54d0ae2 100644
> --- a/weboob/backends/bp/browser.py
> +++ b/weboob/backends/bp/browser.py
> @@ -1,8 +1,6 @@
>  # -*- coding: utf-8 -*-
> -#
> -#    browser.py
> -#
> -#    Copyright 2010 nicolas <nicolas at NicolasDesktop>
> +
> +# Copyright(C) 2010  Nicolas Duhamel
>  #
>  # This program is free software; you can redistribute it and/or modify
>  # it under the terms of the GNU General Public License as published by
> @@ -16,202 +14,57 @@
>  # You should have received a copy of the GNU General Public License
>  # along with this program; if not, write to the Free Software
>  # Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA.
> -#    MA 02110-1301, USA.
> -
> -from datetime import datetime
> -import mechanize
> -import hashlib
> -import re
> -
> -from weboob.tools.parsers import get_parser
> -from weboob.capabilities.bank import Account
> -from weboob.capabilities.bank import Operation
> -from weboob.capabilities.bank import Transfer
> -
> -def remove_html_tags(data):
> -    p = re.compile(r'<.*?>')
> -    return p.sub(' ', data)
> -
> -def remove_extra_spaces(data):
> -    p = re.compile(r'\s+')
> -    return p.sub(' ', data)
> -
> -
> -
> -LOCAL_HASH = ['a02574d7bf67677d2a86b7bfc5e864fe', 'eb85e1cc45dd6bdb3cab65c002d7ac8a', '596e6fbd54d5b111fe5df8a4948e80a4', '9cdc989a4310554e7f5484d0d27a86ce', '0183943de6c0e331f3b9fc49c704ac6d', '291b9987225193ab1347301b241e2187', '163279f1a46082408613d12394e4042a', 'b0a9c740c4cada01eb691b4acda4daea', '3c4307ee92a1f3b571a3c542eafcb330', 'dbccecfa2206bfdb4ca891476404cc68']
> -
> -ENCODING = 'utf-8'
> -
> -class BPbrowser(object):
> -
> -
> -    def __init__(self, login, pwd, **kwargs):
> -
> -        self.is_logged = False
> -
> -        self.login_id = login
> -        self.pwd = pwd
> -
> -        self.parser = get_parser()()
> -
> -        self.Browser = mechanize.Browser()
> -        self.Browser.set_handle_robots(False)
> -
> -        self.Account_List = []
> -
> -
> -
> +from weboob.tools.browser import BaseBrowser, BrowserIncorrectPassword
> +
> +from .pages import LoginPage, CookiePage, AccountList, AccountHistory
> +
> +__all__ = ['BPbrowser']
> +
> +class BPbrowser(BaseBrowser):
> +    DOMAIN = 'voscomptesenligne.labanquepostale.fr'
> +    PROTOCOL = 'https'
> +    ENCODING = None # refer to the HTML encoding
> +    PAGES = { r'.*wsost/OstBrokerWeb/loginform.*':                              LoginPage,
> +              r'.*voscomptes/canalXHTML/releve/syntheseAssurancesEtComptes.ea': CookiePage,
> +              r'.*voscomptes/canalXHTML/releve/liste_comptes.jsp':              AccountList,
> +              r'.*canalXHTML/relevesCCP/.*':                                    AccountHistory,
> +              r'.*canalXHTML/relevesEpargnes/.*':                               AccountHistory,
> +              
> +              
> +            }
> +    def __init__(self, *args, **kwargs):
> +        self.inlogin = False
> +        BaseBrowser.__init__(self, *args, **kwargs)
> +    
> +    def home(self):
> +        self.location("https://voscomptesenligne.labanquepostale.fr/wsost/OstBrokerWeb/loginform?TAM_OP=login&ERROR_CODE=0x00000000&URL=%2Fvoscomptes%2FcanalXHTML%2Fidentif.ea%3Forigin%3Dparticuliers")
> +      
> +    def is_logged(self):
> +        if self.inlogin:
> +            return True
> +        return not self.is_on_page(LoginPage)
>  
>      def login(self):
> -
> -        def md5(file):
> -            f = open(file,'rb')
> -            md5 = hashlib.md5()
> -            md5.update(f.read())
> -            return md5.hexdigest()
> -
> -        self.Browser.open("https://voscomptesenligne.labanquepostale.fr/wsost/OstBrokerWeb/loginform?TAM_OP=login&ERROR_CODE=0x00000000&URL=%2Fvoscomptes%2FcanalXHTML%2Fidentif.ea%3Forigin%3Dparticuliers")
> -
> -        process = lambda i: md5(
> -
> -        self.Browser.retrieve(("https://voscomptesenligne.labanquepostale.fr/wsost/OstBrokerWeb/loginform?imgid=%d&0.25122230781963073" % i ))[0])
> -        Keypad = [ process(i) for i in range(10)]
> -
> -        correspondance = [ Keypad.index(i) for i in LOCAL_HASH]
> -
> -
> -        Newpassword = "".join([str(correspondance[int(c)]) for c in self.pwd])
> -
> -
> -        self.Browser.select_form(name="formAccesCompte")
> -        self.Browser.find_control("password").readonly = False
> -        self.Browser["password"] = Newpassword
> -        self.Browser["username"] = self.login_id
> -
> -        self.Browser.submit()
> -        self.is_logged = True
> -
> +        self.inlogin = True
> +        if not self.is_on_page(LoginPage):
> +            self.location('https://voscomptesenligne.labanquepostale.fr/wsost/OstBrokerWeb/loginform?TAM_OP=login&ERROR_CODE=0x00000000&URL=%2Fvoscomptes%2FcanalXHTML%2Fidentif.ea%3Forigin%3Dparticuliers')
> +            
> +        self.page.login(self.username, self.password)
> +        self.inlogin = False
> +        
>      def get_accounts_list(self):
> -
> -        if self.Account_List:
> -            return self.Account_List
> -
> -
> -
> -        if not self.is_logged:
> -            self.login()
> -
> -        self.Browser.open("https://voscomptesenligne.labanquepostale.fr/voscomptes/canalXHTML/authentification/liste_contrat_atos.ea")
> -        self.Browser.open("https://voscomptesenligne.labanquepostale.fr/voscomptes/canalXHTML/releve/liste_comptes.jsp")
> -
> -        document = self.parser.parse(self.Browser.response(), ENCODING)
> -
> -
> -        #Parse CCP
> -        compte_table = document.xpath("//table[@id='comptes']", smart_strings=False)[0]
> -        compte_ligne = compte_table.xpath("./tbody/tr")
> -
> -        for compte in compte_ligne:
> -            account = Account()
> -            tp = compte.xpath("./td/a")[0]
> -            account.label = tp.text
> -            account.link_id = tp.get("href")
> -            account.id = compte.xpath("./td")[1].text
> -            account.balance = float(''.join( compte.xpath("./td/span")[0].text.replace('.','').replace(',','.').split() ))
> -            self.Account_List.append(account)
> -
> -        #Parse epargne
> -        epargne_table = document.xpath("//table[@id='comptesEpargne']", smart_strings=False)[0]
> -        epargne_ligne = epargne_table.xpath("./tbody/tr")
> -
> -        for epargne in epargne_ligne:
> -            account = Account()
> -            tp = epargne.xpath("./td/a")[0]
> -            account.label = tp.text
> -            account.link_id = tp.get("href")
> -            account.id = epargne.xpath("./td")[1].text
> -            account.balance = float(''.join( epargne.xpath("./td/span")[0].text.replace('.','').replace(',','.').split() ) )
> -            self.Account_List.append(account)
> -
> -        return self.Account_List
> -
> -
> +        self.location("https://voscomptesenligne.labanquepostale.fr/voscomptes/canalXHTML/authentification/liste_contrat_atos.ea")
> +        self.location("https://voscomptesenligne.labanquepostale.fr/voscomptes/canalXHTML/releve/liste_comptes.jsp")
> +        return self.page.get_accounts_list()
> +    
>      def get_account(self, id):
> -        if self.Account_List:
> -            for account in self.Account_List:
> -                if account.id == id:
> -                    return account
> -            return None
> -
> -        self.get_accounts_list()
> -
> -        for account in self.Account_List:
> -                if account.id == id:
> -                    return account
> -        return None
> -
> -
> -    def get_history(self, account):
> -
> -        self.Browser.open(account.link_id)
> -        rep = self.Browser.follow_link(url_regex="releve", tag="a")
> -        document = self.parser.parse(rep, ENCODING)
> -
> -        mvt_table = document.xpath("//table[@id='mouvements']", smart_strings=False)[0]
> -        mvt_ligne = mvt_table.xpath("./tbody/tr")
> -
> -        operations = []
> -
> -        for mvt in mvt_ligne:
> -            operation = Operation(len(operations))
> -            operation.date = mvt.xpath("./td")[0].text
> -            tp = mvt.xpath("./td")[1]
> -            operation.label = remove_extra_spaces(remove_html_tags(self.parser.tostring(tp)))
> -
> -
> -            r = re.compile(r'\d+')
> -            tp = mvt.xpath("./td/span")
> -            amount = None
> -            for t in tp:
> -                if r.search(t.text):
> -                    amount = t.text
> -            amount =  ''.join( amount.replace('.', '').replace(',', '.').split() )
> -            if amount[0] == "-":
> -                operation.amount = -float(amount[1:])
> -            else:
> -                operation.amount = float(amount)
> -
> -            operations.append(operation)
> -        return operations
> -
> -
> -
> -    def make_transfer(self, from_account, to_account, amount):
> -        self.Browser.open("https://voscomptesenligne.labanquepostale.fr/voscomptes/canalXHTML/f_virementSafran.jsp?n=11")
> -        self.Browser.open("https://voscomptesenligne.labanquepostale.fr/voscomptes/canalXHTML/virementsafran/aiguillage/saisieComptes.ea")
> -
> -        self.Browser.select_form(name="AiguillageForm")
> -        self.Browser["idxCompteEmetteur"] = [from_account.id]
> -        self.Browser["idxCompteReceveur"] = [to_account.id]
> -        self.Browser.submit()
> -
> -        self.Browser.select_form(name="VirementNationalForm")
> -        self.Browser["montant"] = str(amount)
> -        self.Browser.submit()
> -
> -        #Confirmation
> -        # TODO: verifier que tout c'est bien passe
> -        rep = self.Browser.open("https://voscomptesenligne.labanquepostale.fr/voscomptes/canalXHTML/virementsafran/virementnational/4-virementNational.ea")
> -        html = rep.get_data()
> -
> -        pattern = "Votre virement N.+ ([0-9]+) "
> -
> -        regex = re.compile(pattern)
> -        match = regex.search(html)
> -        id_transfer = match.groups()[0]
> -        transfer = Transfer(id_transfer)
> -        transfer.amount = amount
> -        transfer.origin = from_account.label
> -        transfer.recipient = to_account.label
> -        transfer.date = datetime.now()
> -        return transfer
> +        
> +        if not self.is_on_page(AccountList):
> +            self.location("https://voscomptesenligne.labanquepostale.fr/voscomptes/canalXHTML/authentification/liste_contrat_atos.ea")
> +            self.location("https://voscomptesenligne.labanquepostale.fr/voscomptes/canalXHTML/releve/liste_comptes.jsp")
> +        return self.page.get_account(id)
> +     
> +     
> +    def get_history(self, Account):
> +        self.location(Account.link_id)
> +        return self.page.get_history()
> diff --git a/weboob/backends/bp/pages/__init__.py b/weboob/backends/bp/pages/__init__.py
> new file mode 100644
> index 0000000..13f121c
> --- /dev/null
> +++ b/weboob/backends/bp/pages/__init__.py
> @@ -0,0 +1,23 @@
> +# -*- coding: utf-8 -*-
> +
> +# Copyright(C) 2010  Nicolas Duhamel
> +#
> +# This program is free software; you can redistribute it and/or modify
> +# it under the terms of the GNU General Public License as published by
> +# the Free Software Foundation, version 3 of the License.
> +#
> +# This program 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 General Public License for more details.
> +#
> +# You should have received a copy of the GNU General Public License
> +# along with this program; if not, write to the Free Software
> +# Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA.
> +
> +from .login import LoginPage
> +from .cookie import CookiePage
> +from .accountlist import AccountList
> +from .accounthistory import AccountHistory
> +
> +__all__ = ['LoginPage', 'CookiePage', "AccountList", 'AccountHistory']
> diff --git a/weboob/backends/bp/pages/accounthistory.py b/weboob/backends/bp/pages/accounthistory.py
> new file mode 100644
> index 0000000..2d18ae0
> --- /dev/null
> +++ b/weboob/backends/bp/pages/accounthistory.py
> @@ -0,0 +1,66 @@
> +# -*- coding: utf-8 -*-
> +
> +# Copyright(C) 2010  Nicolas Duhamel
> +#
> +# This program is free software; you can redistribute it and/or modify
> +# it under the terms of the GNU General Public License as published by
> +# the Free Software Foundation, version 3 of the License.
> +#
> +# This program 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 General Public License for more details.
> +#
> +# You should have received a copy of the GNU General Public License
> +# along with this program; if not, write to the Free Software
> +# Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA.
> +
> +import re
> +
> +from weboob.capabilities.bank import Operation
> +
> +from weboob.tools.browser import BasePage
> +
> +__all__ = ['AccountHistory']
> +
> +def remove_html_tags(data):
> +    p = re.compile(r'<.*?>')
> +    return p.sub(' ', data)
> +
> +def remove_extra_spaces(data):
> +    p = re.compile(r'\s+')
> +    return p.sub(' ', data)
> +
> +
> +class AccountHistory(BasePage):
> +    def on_loaded(self):
> +        if self.document.docinfo.doctype == '<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Frameset//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-frameset.dtd">':
> +            self.browser.follow_link(url_regex="releve", tag="a")
> +                
> +    def get_history(self):
> +        mvt_table = self.document.xpath("//table[@id='mouvements']", smart_strings=False)[0]
> +        mvt_ligne = mvt_table.xpath("./tbody/tr")
> +
> +        operations = []
> +
> +        for mvt in mvt_ligne:
> +            operation = Operation(len(operations))
> +            operation.date = mvt.xpath("./td")[0].text
> +            tp = mvt.xpath("./td")[1]
> +            operation.label = remove_extra_spaces(remove_html_tags(self.browser.parser.tostring(tp)))
> +
> +
> +            r = re.compile(r'\d+')
> +            tp = mvt.xpath("./td/span")
> +            amount = None
> +            for t in tp:
> +                if r.search(t.text):
> +                    amount = t.text
> +            amount =  ''.join( amount.replace('.', '').replace(',', '.').split() )
> +            if amount[0] == "-":
> +                operation.amount = -float(amount[1:])
> +            else:
> +                operation.amount = float(amount)
> +
> +            operations.append(operation)
> +        return operations
> diff --git a/weboob/backends/bp/pages/accountlist.py b/weboob/backends/bp/pages/accountlist.py
> new file mode 100644
> index 0000000..2317379
> --- /dev/null
> +++ b/weboob/backends/bp/pages/accountlist.py
> @@ -0,0 +1,71 @@
> +# -*- coding: utf-8 -*-
> +
> +# Copyright(C) 2010  Nicolas Duhamel
> +#
> +# This program is free software; you can redistribute it and/or modify
> +# it under the terms of the GNU General Public License as published by
> +# the Free Software Foundation, version 3 of the License.
> +#
> +# This program 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 General Public License for more details.
> +#
> +# You should have received a copy of the GNU General Public License
> +# along with this program; if not, write to the Free Software
> +# Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA.
> +
> +
> +from weboob.capabilities.bank import Account, AccountNotFound
> +
> +from weboob.tools.browser import BasePage
> +
> +__all__ = ['AccountList']
> +
> +class AccountList(BasePage):
> +    def on_loaded(self):
> +        self.Account_List = []
> +            
> +    def get_accounts_list(self):
> +        
> +        #Parse CCP
> +        compte_table = self.document.xpath("//table[@id='comptes']", smart_strings=False)[0]
> +        compte_ligne = compte_table.xpath("./tbody/tr")
> +
> +        for compte in compte_ligne:
> +            account = Account()
> +            tp = compte.xpath("./td/a")[0]
> +            account.label = tp.text
> +            account.link_id = tp.get("href")
> +            account.id = compte.xpath("./td")[1].text
> +            account.balance = float(''.join( compte.xpath("./td/span")[0].text.replace('.','').replace(',','.').split() ))
> +            self.Account_List.append(account)
> +
> +        #Parse epargne
> +        epargne_table = self.document.xpath("//table[@id='comptesEpargne']", smart_strings=False)[0]
> +        epargne_ligne = epargne_table.xpath("./tbody/tr")
> +
> +        for epargne in epargne_ligne:
> +            account = Account()
> +            tp = epargne.xpath("./td/a")[0]
> +            account.label = tp.text
> +            account.link_id = tp.get("href")
> +            account.id = epargne.xpath("./td")[1].text
> +            account.balance = float(''.join( epargne.xpath("./td/span")[0].text.replace('.','').replace(',','.').split() ) )
> +            self.Account_List.append(account)
> +
> +        return self.Account_List
> +
> +    def get_account(self, id):
> +        if self.Account_List:
> +            for account in self.Account_List:
> +                if account.id == id:
> +                    return account
> +            return AccountNotFound()
> +
> +        self.get_accounts_list()
> +
> +        for account in self.Account_List:
> +                if account.id == id:
> +                    return account
> +        return AccountNotFound()
> diff --git a/weboob/backends/bp/pages/cookie.py b/weboob/backends/bp/pages/cookie.py
> new file mode 100644
> index 0000000..bd4e79c
> --- /dev/null
> +++ b/weboob/backends/bp/pages/cookie.py
> @@ -0,0 +1,26 @@
> +# -*- coding: utf-8 -*-
> +
> +# Copyright(C) 2010  Nicolas Duhamel
> +#
> +# This program is free software; you can redistribute it and/or modify
> +# it under the terms of the GNU General Public License as published by
> +# the Free Software Foundation, version 3 of the License.
> +#
> +# This program 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 General Public License for more details.
> +#
> +# You should have received a copy of the GNU General Public License
> +# along with this program; if not, write to the Free Software
> +# Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA.
> +
> +
> +
> +from weboob.tools.browser import BasePage
> +
> +__all__ = ['CookiePage']
> +
> +class CookiePage(BasePage):
> +    def on_loaded(self):
> +        pass
> diff --git a/weboob/backends/bp/pages/login.py b/weboob/backends/bp/pages/login.py
> new file mode 100644
> index 0000000..2a97e8d
> --- /dev/null
> +++ b/weboob/backends/bp/pages/login.py
> @@ -0,0 +1,52 @@
> +# -*- coding: utf-8 -*-
> +
> +# Copyright(C) 2010  Nicolas Duhamel
> +#
> +# This program is free software; you can redistribute it and/or modify
> +# it under the terms of the GNU General Public License as published by
> +# the Free Software Foundation, version 3 of the License.
> +#
> +# This program 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 General Public License for more details.
> +#
> +# You should have received a copy of the GNU General Public License
> +# along with this program; if not, write to the Free Software
> +# Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA.
> +
> +import hashlib
> +
> +from weboob.tools.browser import BasePage
> +
> +__all__ = ['LoginPage']
> +
> +
> +
> +def md5(file):
> +    f = open(file,'rb')
> +    md5 = hashlib.md5()
> +    md5.update(f.read())
> +    return md5.hexdigest()
> +
> +
> +class LoginPage(BasePage):
> +    def on_loaded(self):
> +        pass
> +    
> +    def login(self, login, pwd):
> +        LOCAL_HASH = ['a02574d7bf67677d2a86b7bfc5e864fe', 'eb85e1cc45dd6bdb3cab65c002d7ac8a', '596e6fbd54d5b111fe5df8a4948e80a4', '9cdc989a4310554e7f5484d0d27a86ce', '0183943de6c0e331f3b9fc49c704ac6d', '291b9987225193ab1347301b241e2187', '163279f1a46082408613d12394e4042a', 'b0a9c740c4cada01eb691b4acda4daea', '3c4307ee92a1f3b571a3c542eafcb330', 'dbccecfa2206bfdb4ca891476404cc68']
> +        process = lambda i: md5(self.browser.retrieve(("https://voscomptesenligne.labanquepostale.fr/wsost/OstBrokerWeb/loginform?imgid=%d&0.25122230781963073" % i ))[0])
> +        Keypad = [ process(i) for i in range(10)]
> +        
> +
> +        
> +        
> +        correspondance = [ Keypad.index(i) for i in LOCAL_HASH]
> +        Newpassword = "".join([str(correspondance[int(c)]) for c in pwd])
> +
> +        self.browser.select_form(name="formAccesCompte")
> +        self.browser.set_all_readonly(False)
> +        self.browser["password"] = Newpassword
> +        self.browser["username"] = login
> +        self.browser.submit()
-------------- next part --------------
A non-text attachment was scrubbed...
Name: not available
Type: application/pgp-signature
Size: 489 bytes
Desc: not available
URL: <https://lists.symlink.me/pipermail/weboob/attachments/20101110/bda77e70/attachment.sig>


More information about the weboob mailing list