VMM/cli/handler: CliHandler.user_password: Only prompt for the v0.6.x
authorPascal Volk <neverseen@users.sourceforge.net>
Thu, 05 Aug 2010 02:38:20 +0000 (2010-08-05)
branchv0.6.x
changeset 339 abff2de9eed0
parent 338 45834dcc280e
child 340 4515afec62e5
VMM/cli/handler: CliHandler.user_password: Only prompt for the password if the Account exists.
VirtualMailManager/cli/handler.py
--- a/VirtualMailManager/cli/handler.py	Thu Aug 05 00:12:52 2010 +0000
+++ b/VirtualMailManager/cli/handler.py	Thu Aug 05 02:38:20 2010 +0000
@@ -14,7 +14,8 @@
 from VirtualMailManager.handler import Handler
 from VirtualMailManager.cli import read_pass
 from VirtualMailManager.cli.config import CliConfig as Cfg
-from VirtualMailManager.constants import ACCOUNT_EXISTS, INVALID_SECTION
+from VirtualMailManager.constants import ACCOUNT_EXISTS, INVALID_SECTION, \
+     NO_SUCH_ACCOUNT
 
 _ = lambda msg: msg
 
@@ -81,10 +82,14 @@
         self._make_account_dirs(acc)
 
     def user_password(self, emailaddress, password=None):
-        """Prefix the parent user_password() with the interactive password
-        dialog."""
-        if password is None:
+        """Override the parent user_password() - add the interactive
+        password dialog."""
+        acc = self._get_account(emailaddress)
+        if not acc:
+            raise VMMError(_(u"The account '%s' doesn't exist.") %
+                           acc.address, NO_SUCH_ACCOUNT)
+        if not isinstance(password, basestring) or not password:
             password = read_pass()
-        super(CliHandler, self).user_password(emailaddress, password)
+        acc.modify('password', password)
 
 del _