X-Git-Url: https://projects.mako.cc/source/mw/blobdiff_plain/2c712c501ee2e538d09ad94cf25c5749471c7bfd..104bad54d78037d8ef3102fcc110d380d77d1479:/src/mw/clicommands.py diff --git a/src/mw/clicommands.py b/src/mw/clicommands.py index 3c0b448..33c4177 100644 --- a/src/mw/clicommands.py +++ b/src/mw/clicommands.py @@ -57,8 +57,11 @@ class CommandBase(object): result = self.api.call({'action': 'login', 'lgname': user, 'lgpassword': passwd}) - if result['login']['result'] != 'Success': - raise Exception('Login error: %s' % result['login']['result']) + if result['login']['result'] == 'Success': + # cookies are saved to a file + print 'Login successful! (yay)' + else: + print 'Login failed: %s' % result['login']['result'] def _die_if_no_init(self): if self.metadir.config is None: @@ -67,7 +70,7 @@ class CommandBase(object): def _api_setup(self): self.api_url = self.metadir.config.get('remote', 'api_url') - self.api = mw.api.API(self.api_url) + self.api = mw.api.API(self.api_url, self.metadir) class InitCommand(CommandBase): @@ -75,15 +78,37 @@ class InitCommand(CommandBase): def __init__(self): usage = 'API_URL' CommandBase.__init__(self, 'init', 'start a mw repo', usage) - self.parser.add_option('-u', '--username', dest='username', - help='use wiki with login') def _do_command(self): if len(self.args) < 1: self.parser.error('must have URL to remote api.php') elif len(self.args) > 1: self.parser.error('too many arguments') - self.metadir.create(self.args[0], self.options.username) + self.metadir.create(self.args[0]) + + +class LoginCommand(CommandBase): + + def __init__(self): + CommandBase.__init__(self, 'login', 'authenticate with wiki') + + def _do_command(self): + self._die_if_no_init() + self._api_setup() + self._login() + + +class LogoutCommand(CommandBase): + + def __init__(self): + CommandBase.__init__(self, 'logout', 'forget authentication') + + def _do_command(self): + self._die_if_no_init() + try: + os.unlink(os.path.join(self.metadir.location, 'cookies')) + except OSError: + pass class PullCommand(CommandBase): @@ -148,3 +173,14 @@ class DiffCommand(CommandBase): print self.metadir.diff_rv_to_working( mw.api.filename_to_pagename(file[:-5]) ), + + +class CommitCommand(CommandBase): + + def __init__(self): + CommandBase.__init__(self, 'commit', 'commit changes to wiki') + self.shortcuts.append('ci') + + def _do_command(self): + self._die_if_no_init() + self._api_setup()