# -*- coding: utf-8 -*- # Copyright(C) 2010 Romain Bignon, 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. import ConfigParser import logging import os import subprocess import re from weboob.tools.application.console import ConsoleApplication from weboob.tools.ordereddict import OrderedDict __all__ = ['WeboobCfg'] class WeboobCfg(ConsoleApplication): APPNAME = 'weboob-config' VERSION = '0.1' COPYRIGHT = 'Copyright(C) 2010 Christophe Benz, Romain Bignon' def main(self, argv): return self.process_command(*argv[1:]) def caps_included(self, modcaps, caps): modcaps = [x.__name__ for x in modcaps] for cap in caps: if not cap in modcaps: return False return True @ConsoleApplication.command('Add a configured backend') def command_add(self, name, *options): self.weboob.backends_loader.load_all() if name not in [_name for _name, backend in self.weboob.backends_loader.loaded.iteritems()]: logging.error(u'Backend "%s" does not exist.' % name) return 1 params = {} # set backend params from command-line arguments for option in options: try: key, value = option.split('=', 1) except ValueError: logging.error(u'Parameters have to be formatted "key=value"') return 1 params[key] = value # ask for params non-specified on command-line arguments backend = self.weboob.backends_loader.get_or_load_backend(name) asked_config = False for key, value in backend.config.iteritems(): if not asked_config: asked_config = True print 'Configuration of backend' print '------------------------' if key not in params: params[key] = self.ask(' [%s] %s' % (key, value.description), default=value.default, masked=value.is_masked, choices=value.choices, regexp=value.regexp) else: print ' [%s] %s: %s' % (key, value.description, '(masked)' if value.is_masked else params[key]) if asked_config: print '------------------------' try: self.weboob.backends_config.add_backend(name, name, params) print 'Backend "%s" successfully added to file "%s".\n'\ 'Please check configuration parameters values with "weboob-config edit".' % ( name, self.weboob.backends_config.confpath) except ConfigParser.DuplicateSectionError: print 'Backend "%s" is already configured in file "%s"' % (name, self.weboob.backends_config.confpath) response = raw_input(u'Add new instance of "%s" backend? [yN] ' % name) if response.lower() == 'y': while True: new_name = raw_input(u'Please give new instance name (could be "%s_1"): ' % name) if not new_name: continue try: self.weboob.backends_config.add_backend(new_name, name, params) print 'Backend "%s" successfully added to file "%s".\n'\ 'Please check configuration parameters values with "weboob-config edit".' % ( name, self.weboob.backends_config.confpath) break except ConfigParser.DuplicateSectionError: print 'Instance "%s" already exists for backend "%s".' % (new_name, name) @ConsoleApplication.command('Show configured backends') def command_listconfigured(self): self.set_default_formatter('table') for instance_name, name, params in sorted(self.weboob.backends_config.iter_backends()): backend = self.weboob.backends_loader.get_or_load_backend(name) row = OrderedDict([('Instance name', instance_name), ('Backend name', name), ('Configuration', ', '.join('%s=%s' % (key, ('*****' if backend.config[key].is_masked else value)) for key, value in params.iteritems())), ]) self.format(row) @ConsoleApplication.command('Remove a configured backend') def command_remove(self, instance_name): try: self.weboob.backends_config.remove_backend(instance_name) except ConfigParser.NoSectionError: logging.error('Backend instance "%s" does not exist' % instance_name) return 1 @ConsoleApplication.command('Edit configuration file') def command_edit(self): subprocess.call([os.environ.get('EDITOR', 'vi'), self.weboob.backends_config.confpath]) @ConsoleApplication.command('Show available backends') def command_backends(self, *caps): self.set_default_formatter('table') self.weboob.backends_loader.load_all() for name, backend in sorted(self.weboob.backends_loader.loaded.iteritems()): if caps and not self.caps_included(backend.iter_caps(), caps): continue row = OrderedDict([('Name', name), ('Capabilities', ', '.join(cap.__name__ for cap in backend.iter_caps())), ('Description', backend.description), ]) self.format(row) @ConsoleApplication.command('Display information about a backend') def command_info(self, name): try: backend = self.weboob.backends_loader.get_or_load_backend(name) except KeyError: logging.error('No such backend: "%s"' % name) return 1 print '.------------------------------------------------------------------------------.' print '| Backend %-68s |' % backend.name print "+-----------------.------------------------------------------------------------'" print '| Version | %s' % backend.version print '| Maintainer | %s' % backend.maintainer print '| License | %s' % backend.license print '| Description | %s' % backend.description print '| Capabilities | %s' % ', '.join([cap.__name__ for cap in backend.iter_caps()]) first = True for key, field in backend.config.iteritems(): value = field.description if not field.default is None: value += ' (default: %s)' % field.default if first: print '| | ' print '| Configuration | %s: %s' % (key, value) first = False else: print '| | %s: %s' % (key, value) print "'-----------------'" @ConsoleApplication.command('Show applications') def command_applications(self, *caps): applications = set() import weboob.applications for path in weboob.applications.__path__: regexp = re.compile('^%s/([\w\d_]+)$' % path) for root, dirs, files in os.walk(path): m = regexp.match(root) if m and '__init__.py' in files: applications.add(m.group(1)) print ' '.join(sorted(applications)).encode('utf-8')