From 8bb58b6fe79747815aac16b293155efbd5e24dfc Mon Sep 17 00:00:00 2001 From: Christophe Benz Date: Wed, 14 Apr 2010 18:37:33 +0200 Subject: [PATCH] move boobank useful code into weboob.frontends.boobank --- scripts/boobank | 59 +------------------- scripts/monfric | 2 +- weboob/frontends/boobank/__init__.py | 22 ++++++++ weboob/frontends/boobank/boobank.py | 83 ++++++++++++++++++++++++++++ 4 files changed, 107 insertions(+), 59 deletions(-) create mode 100644 weboob/frontends/boobank/boobank.py diff --git a/scripts/boobank b/scripts/boobank index 4ba8fd9289..63643f3dbf 100755 --- a/scripts/boobank +++ b/scripts/boobank @@ -20,64 +20,7 @@ Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA. """ -from __future__ import with_statement - -import sys - -import weboob -from weboob.capabilities.bank import ICapBank, AccountNotFound -from weboob.tools.application import ConsoleApplication - -class Boobank(ConsoleApplication): - APPNAME = 'boobank' - - def main(self, argv): - self.weboob.load_backends(ICapBank) - - return self.process_command(*argv[1:]) - - @ConsoleApplication.command('List every available accounts') - def command_list(self): - accounts = [] - for name, backend, in self.weboob.iter_backends(): - try: - for account in backend.iter_accounts(): - accounts.append('%17s %-20s %11.2f %11.2f' % ( - account.id, account.label, account.balance, account.coming)) - except weboob.tools.browser.BrowserIncorrectPassword: - print >>sys.stderr, 'Error: Incorrect password for backend %s' % name - return 1 - if len(accounts): - print ' ID Account Balance Coming ' - print '+-----------------+---------------------+--------------+-------------+' - print '\n'.join(accounts) - else: - print 'No accounts found' - - @ConsoleApplication.command('Display all future operations') - def command_coming(self, id): - operations = [] - found = 0 - for name, backend in self.weboob.iter_backends(): - try: - account = backend.get_account(id) - except AccountNotFound: - if found == 0: - found = -1 - else: - found = 1 - for operation in backend.iter_operations(account): - operations.append(' %8s %-50s %11.2f' % (operation.date, operation.label, operation.amount)) - if found < 0: - print >>sys.stderr, "Error: account %s not found" % id - return 1 - else: - if operations: - print ' Date Label Amount ' - print '+----------+----------------------------------------------------+-------------+' - print '\n'.join(operations) - else: - print 'No coming operations for ID=%s' % id +from weboob.frontends.boobank import Boobank if __name__ == '__main__': Boobank.run() diff --git a/scripts/monfric b/scripts/monfric index cda8003368..406b683e2e 100755 --- a/scripts/monfric +++ b/scripts/monfric @@ -20,7 +20,7 @@ Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA. """ -from weboob.frontends.boobank.monfric import MonFric +from weboob.frontends.boobank import MonFric if __name__ == '__main__': MonFric.run() diff --git a/weboob/frontends/boobank/__init__.py b/weboob/frontends/boobank/__init__.py index e69de29bb2..bc676d0507 100644 --- a/weboob/frontends/boobank/__init__.py +++ b/weboob/frontends/boobank/__init__.py @@ -0,0 +1,22 @@ +# -*- coding: utf-8 -*- + +""" +Copyright(C) 2010 Christophe Benz + +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 .boobank import Boobank +from .monfric import MonFric diff --git a/weboob/frontends/boobank/boobank.py b/weboob/frontends/boobank/boobank.py new file mode 100644 index 0000000000..4ba8fd9289 --- /dev/null +++ b/weboob/frontends/boobank/boobank.py @@ -0,0 +1,83 @@ +#!/usr/bin/env python +# -*- coding: utf-8 -*- +# vim: ft=python et softtabstop=4 cinoptions=4 shiftwidth=4 ts=4 ai + +""" +Copyright(C) 2009-2010 Romain Bignon + +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 __future__ import with_statement + +import sys + +import weboob +from weboob.capabilities.bank import ICapBank, AccountNotFound +from weboob.tools.application import ConsoleApplication + +class Boobank(ConsoleApplication): + APPNAME = 'boobank' + + def main(self, argv): + self.weboob.load_backends(ICapBank) + + return self.process_command(*argv[1:]) + + @ConsoleApplication.command('List every available accounts') + def command_list(self): + accounts = [] + for name, backend, in self.weboob.iter_backends(): + try: + for account in backend.iter_accounts(): + accounts.append('%17s %-20s %11.2f %11.2f' % ( + account.id, account.label, account.balance, account.coming)) + except weboob.tools.browser.BrowserIncorrectPassword: + print >>sys.stderr, 'Error: Incorrect password for backend %s' % name + return 1 + if len(accounts): + print ' ID Account Balance Coming ' + print '+-----------------+---------------------+--------------+-------------+' + print '\n'.join(accounts) + else: + print 'No accounts found' + + @ConsoleApplication.command('Display all future operations') + def command_coming(self, id): + operations = [] + found = 0 + for name, backend in self.weboob.iter_backends(): + try: + account = backend.get_account(id) + except AccountNotFound: + if found == 0: + found = -1 + else: + found = 1 + for operation in backend.iter_operations(account): + operations.append(' %8s %-50s %11.2f' % (operation.date, operation.label, operation.amount)) + if found < 0: + print >>sys.stderr, "Error: account %s not found" % id + return 1 + else: + if operations: + print ' Date Label Amount ' + print '+----------+----------------------------------------------------+-------------+' + print '\n'.join(operations) + else: + print 'No coming operations for ID=%s' % id + +if __name__ == '__main__': + Boobank.run() -- GitLab