From 3860f87f76f0de05f0c3cd89932e6b2fe9a26bbc Mon Sep 17 00:00:00 2001 From: Romain Bignon Date: Sun, 31 Oct 2010 10:26:06 +0100 Subject: [PATCH] return a Transfer object insetad of only an ID --- weboob/backends/bp/backend.py | 3 ++- weboob/backends/bp/browser.py | 19 +++++++++++++------ weboob/capabilities/bank.py | 33 ++++++++++++++++++++++++++------- 3 files changed, 41 insertions(+), 14 deletions(-) diff --git a/weboob/backends/bp/backend.py b/weboob/backends/bp/backend.py index ca7d6738..952433df 100644 --- a/weboob/backends/bp/backend.py +++ b/weboob/backends/bp/backend.py @@ -52,9 +52,10 @@ class BPBackend(BaseBackend, ICapBank): for history in self.browser.get_history(account): yield history - def transfer(self, id_from, id_to, amount): + 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 3a054d6f..433b1e98 100644 --- a/weboob/backends/bp/browser.py +++ b/weboob/backends/bp/browser.py @@ -18,6 +18,7 @@ # 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 @@ -25,6 +26,7 @@ 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'<.*?>') @@ -71,12 +73,12 @@ class BPbrowser(object): 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]) @@ -201,10 +203,15 @@ class BPbrowser(object): # 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] - return id_transfer + transfer = Transfer(id_transfer) + transfer.amount = amount + transfer.origin = from_account.label + transfer.recipient = to_account.label + transfer.date = datetime.now() + return transfer diff --git a/weboob/capabilities/bank.py b/weboob/capabilities/bank.py index 201f48ca..1b935bd8 100644 --- a/weboob/capabilities/bank.py +++ b/weboob/capabilities/bank.py @@ -21,16 +21,18 @@ from datetime import datetime from .base import IBaseCap, CapBaseObject -__all__ = ['Account', 'AccountNotFound', 'NotEnoughMoney', 'ICapBank', 'Operation'] +__all__ = ['Account', 'AccountNotFound', 'TransferError', 'ICapBank', 'Operation'] class AccountNotFound(Exception): - pass + def __init__(self, msg=None): + if msg is None: + msg = 'Account not found' + Exception.__init__(self, msg) -class NotEnoughMoney(Exception): +class TransferError(Exception): pass - class Account(CapBaseObject): def __init__(self): CapBaseObject.__init__(self, 0) @@ -53,6 +55,14 @@ class Operation(CapBaseObject): def __repr__(self): return "" % (self.date, self.label, self.amount) +class Transfer(CapBaseObject): + def __init__(self, id): + CapBaseObject.__init__(self, id) + self.add_field('amount', float) + self.add_field('date', (basestring,datetime)) + self.add_field('origin', (int,long,basestring)) + self.add_field('recipient', (int,long,basestring)) + class ICapBank(IBaseCap): def iter_accounts(self): raise NotImplementedError() @@ -63,8 +73,17 @@ class ICapBank(IBaseCap): def iter_operations(self, account): raise NotImplementedError() - def iter_history(self, id): + def iter_history(self, account): raise NotImplementedError() - def transfer(self, id_from, id_to, amount): - raise NotImplementedError() + def transfer(self, account, to, amount, reason=None): + """ + Make a transfer from an account to a recipient. + + @param account [Account] account to take money + @param to [Account] account to send money + @param amount [float] amount + @param reason [str] reason of transfer + @return [Transfer] a Transfer object + """ + raise NotImplementedError()