diff options
-rw-r--r-- | ipalib/cli.py | 2 | ||||
-rw-r--r-- | ipalib/public.py | 11 |
2 files changed, 9 insertions, 4 deletions
diff --git a/ipalib/cli.py b/ipalib/cli.py index d199f721..abaef030 100644 --- a/ipalib/cli.py +++ b/ipalib/cli.py @@ -164,7 +164,7 @@ class CLI(object): print '>>> %s: %s' % (option.name, error) raw = raw_input(prompt) try: - value = option(raw) + value = option(raw, **kw) if value is not None: kw[option.name] = value break diff --git a/ipalib/public.py b/ipalib/public.py index d1f2ff35..7734bf7a 100644 --- a/ipalib/public.py +++ b/ipalib/public.py @@ -164,7 +164,10 @@ class Option(plugable.ReadOnly): if self.default_from is not None: default = self.default_from(**kw) if default is not None: - return self.convert(default) + try: + return self.convert(self.normalize(default)) + except errors.ValidationError: + return None return self.default def get_values(self): @@ -179,10 +182,12 @@ class Option(plugable.ReadOnly): value = self.get_default(**kw) if value is None: if self.required: - raise RequirementError(option.name) + raise errors.RequirementError(self.name) return None else: - pass + value = self.convert(self.normalize(value)) + self.validate(value) + return value class Command(plugable.Plugin): |