summaryrefslogtreecommitdiffstats
path: root/ipalib
diff options
context:
space:
mode:
authorMartin Nagy <mnagy@redhat.com>2008-10-17 22:55:03 +0200
committerMartin Nagy <mnagy@redhat.com>2008-10-17 23:11:51 +0200
commit3a80297b04d6fbfd2367ec76c5651d20293adccc (patch)
tree8f10d8b3c490dec9b29077ffaa4052bb03c27fea /ipalib
parentae8370be44d95b9f6793ded46ef81126aebef3e0 (diff)
downloadfreeipa-3a80297b04d6fbfd2367ec76c5651d20293adccc.tar.gz
freeipa-3a80297b04d6fbfd2367ec76c5651d20293adccc.tar.xz
freeipa-3a80297b04d6fbfd2367ec76c5651d20293adccc.zip
Reworking Environment, moved it to config.py
Diffstat (limited to 'ipalib')
-rw-r--r--ipalib/cli.py25
-rw-r--r--ipalib/config.py211
-rw-r--r--ipalib/plugable.py72
3 files changed, 179 insertions, 129 deletions
diff --git a/ipalib/cli.py b/ipalib/cli.py
index 5dd2c44f2..07956e0a7 100644
--- a/ipalib/cli.py
+++ b/ipalib/cli.py
@@ -25,11 +25,12 @@ import re
import sys
import code
import optparse
+
import frontend
import errors
import plugable
import ipa_types
-import config
+from config import set_default_env, read_config
def exit_error(error):
sys.exit('ipa: ERROR: %s' % error)
@@ -207,7 +208,6 @@ class CLI(object):
self.__api = api
self.__all_interactive = False
self.__not_interactive = False
- self.__config = None
def __get_api(self):
return self.__api
@@ -256,9 +256,8 @@ class CLI(object):
def run(self):
self.finalize()
- (args, env_dict) = self.parse_globals()
- env_dict.update(config.read_config(self.__config))
- self.api.env.update(config.generate_env(env_dict))
+ set_default_env(self.api.env)
+ args = self.parse_globals()
if len(args) < 1:
self.print_commands()
print 'Usage: ipa [global-options] COMMAND'
@@ -329,7 +328,6 @@ class CLI(object):
return parser
def parse_globals(self, argv=sys.argv[1:]):
- env_dict = {}
parser = optparse.OptionParser()
parser.disable_interspersed_args()
parser.add_option('-a', dest='interactive', action='store_true',
@@ -348,20 +346,23 @@ class CLI(object):
self.__all_interactive = True
elif options.interactive == False:
self.__not_interactive = True
- if options.config_file:
- self.__config = options.config_file
+ if options.verbose != None:
+ self.api.env.verbose = True
if options.environment:
+ env_dict = {}
for a in options.environment.split(','):
a = a.split('=', 1)
if len(a) < 2:
parser.error('badly specified environment string,'\
'use var1=val1[,var2=val2]..')
env_dict[a[0].strip()] = a[1].strip()
- if options.verbose != None:
- env_dict.update(verbose=True)
-
- return (args, env_dict)
+ self.api.env.update(env_dict, True)
+ if options.config_file:
+ self.api.env.update(read_config(options.config_file), True)
+ else:
+ self.api.env.update(read_config(), True)
+ return args
def get_usage(self, cmd):
return ' '.join(self.get_usage_iter(cmd))
diff --git a/ipalib/config.py b/ipalib/config.py
index 42bf7787b..7899d077f 100644
--- a/ipalib/config.py
+++ b/ipalib/config.py
@@ -21,74 +21,193 @@ from ConfigParser import SafeConfigParser, ParsingError
import types
import os
+from errors import check_isinstance, raise_TypeError
+
DEFAULT_CONF='/etc/ipa/ipa.conf'
-def generate_env(d={}):
- default = dict(
- container_accounts = 'cn=accounts',
- basedn = 'dc=example,dc=com',
- container_user = 'cn=users,cn=accounts',
- container_group = 'cn=groups,cn=accounts',
- container_service = 'cn=services,cn=accounts',
- domain = LazyProp(get_domain),
- interactive = True,
- query_dns = True,
- realm = LazyProp(get_realm),
- server_context = True,
- server = LazyIter(get_servers),
- verbose = False,
- )
- for key, value in d.iteritems():
- if key in default:
- if isinstance(default[key], (LazyIter, LazyProp)):
- default[key].set_value(value)
+
+class Environment(object):
+ """
+ A mapping object used to store the environment variables.
+ """
+
+ def __init__(self):
+ object.__setattr__(self, '_Environment__map', {})
+
+ def __getattr__(self, name):
+ """
+ Return the attribute named ``name``.
+ """
+ return self[name]
+
+ def __setattr__(self, name, value):
+ """
+ Set the attribute named ``name`` to ``value``.
+ """
+ self[name] = value
+
+ def __delattr__(self, name):
+ """
+ Raise AttributeError (deletion is not allowed).
+ """
+ raise AttributeError('cannot del %s.%s' %
+ (self.__class__.__name__, name)
+ )
+
+ def __getitem__(self, key):
+ """
+ Return the value corresponding to ``key``.
+ """
+ val = self.__map[key]
+ if hasattr(val, 'get_value'):
+ return val.get_value()
+ else:
+ return val
+
+ def __setitem__(self, key, value):
+ """
+ Set the item at ``key`` to ``value``.
+ """
+ if key in self or hasattr(self, key):
+ if hasattr(self.__map[key], 'set_value'):
+ self.__map[key].set_value(value)
else:
- default[key] = convert_val(type(default[key]), value)
+ raise AttributeError('cannot overwrite %s.%s' %
+ (self.__class__.__name__, key)
+ )
else:
- default[key] = value
+ self.__map[key] = value
- return default
+ def __contains__(self, key):
+ """
+ Return True if instance contains ``key``; otherwise return False.
+ """
+ return key in self.__map
+ def __iter__(self):
+ """
+ Iterate through keys in ascending order.
+ """
+ for key in sorted(self.__map):
+ yield key
-# TODO: Add a validation function
-def convert_val(target_type, value):
- bool_true = ('true', 'yes', 'on')
- bool_false = ('false', 'no', 'off')
+ def update(self, new_vals, ignore_errors = False):
+ assert type(new_vals) == dict
+ for key, value in new_vals.iteritems():
+ if ignore_errors:
+ try:
+ self[key] = value
+ except (AttributeError, KeyError):
+ pass
+ else:
+ self[key] = value
- if target_type == bool and isinstance(value, basestring):
- if value.lower() in bool_true:
- return True
- elif value.lower() in bool_false:
- return False
- return target_type(value)
+ def get(self, name, default=None):
+ return self.__map.get(name, default)
-class LazyProp(object):
- def __init__(self, func, value=None):
- assert isinstance(func, types.FunctionType)
- self._func = func
- self._value = value
- def set_value(self, value):
- self._value = value
+def set_default_env(env):
+ assert isinstance(env, Environment)
+
+ default = dict(
+ basedn = EnvProp(basestring, 'dc=example,dc=com'),
+ container_accounts = EnvProp(basestring, 'cn=accounts'),
+ container_user = EnvProp(basestring, 'cn=users,cn=accounts'),
+ container_group = EnvProp(basestring, 'cn=groups,cn=accounts'),
+ container_service = EnvProp(basestring, 'cn=services,cn=accounts'),
+ domain = LazyProp(basestring, get_domain),
+ interactive = EnvProp(bool, True),
+ query_dns = EnvProp(bool, True),
+ realm = LazyProp(basestring, get_realm),
+ server_context = EnvProp(bool, True),
+ server = LazyIter(basestring, get_servers),
+ verbose = EnvProp(bool, False),
+ )
+
+ env.update(default)
+
+
+class EnvProp(object):
+ def __init__(self, type_, default, multi_value=False):
+ if multi_value:
+ if isinstance(default, tuple) and len(default):
+ check_isinstance(default[0], type_, allow_none=True)
+ self._type = type_
+ self._default = default
+ self._value = None
+ self._multi_value = multi_value
def get_value(self):
- if self._value == None:
- return self._func()
+ if self._get() != None:
+ return self._get()
else:
+ raise KeyError, 'Value not set'
+
+ def set_value(self, value):
+ if self._value != None:
+ raise KeyError, 'Value already set'
+ self._value = self._validate(value)
+
+ def _get(self):
+ if self._value != None:
return self._value
+ elif self._default != None:
+ return self._default
+ else:
+ return None
+
+ def _validate(self, value):
+ if self._multi_value and isinstance(value, tuple):
+ converted = []
+ for val in value:
+ converted.append(self._validate_value(val))
+ return tuple(converted)
+ else:
+ return self._validate_value(value)
+
+ def _validate_value(self, value):
+ bool_true = ('true', 'yes', 'on')
+ bool_false = ('false', 'no', 'off')
+
+ if self._type == bool and isinstance(value, basestring):
+ if value.lower() in bool_true:
+ return True
+ elif value.lower() in bool_false:
+ return False
+ else:
+ raise raise_TypeError(value, bool, 'value')
+ check_isinstance(value, self._type, 'value')
+ return value
+
+
+class LazyProp(EnvProp):
+ def __init__(self, type_, func, default=None, multi_value=False):
+ check_isinstance(func, types.FunctionType, 'func')
+ self._func = func
+ EnvProp.__init__(self, type_, default, multi_value)
+
+ def get_value(self):
+ if self._get() != None:
+ return self._get()
+ else:
+ return self._func()
class LazyIter(LazyProp):
+ def __init__(self, type_, func, default=None):
+ LazyProp.__init__(self, type_, func, default, multi_value=True)
+
def get_value(self):
- if self._value != None:
- if type(self._value) == tuple:
- for item in self._value:
+ val = self._get()
+ if val != None:
+ if type(val) == tuple:
+ for item in val:
yield item
else:
- yield self._value
+ yield val
for item in self._func():
- if not self._value or item not in self._value:
+ if not val or item not in val:
yield item
diff --git a/ipalib/plugable.py b/ipalib/plugable.py
index 4a2658a74..98aa41720 100644
--- a/ipalib/plugable.py
+++ b/ipalib/plugable.py
@@ -29,6 +29,7 @@ import re
import inspect
import errors
from errors import check_type, check_isinstance
+from config import Environment
class ReadOnly(object):
@@ -692,77 +693,6 @@ class Registrar(DictProxy):
self.__registered.add(klass)
-class Environment(object):
- """
- A mapping object used to store the environment variables.
- """
-
- def __init__(self):
- object.__setattr__(self, '_Environment__map', {})
-
- def __getattr__(self, name):
- """
- Return the attribute named ``name``.
- """
- return self[name]
-
- def __setattr__(self, name, value):
- """
- Set the attribute named ``name`` to ``value``.
- """
- self[name] = value
-
- def __delattr__(self, name):
- """
- Raise AttributeError (deletion is not allowed).
- """
- raise AttributeError('cannot del %s.%s' %
- (self.__class__.__name__, name)
- )
-
- def __getitem__(self, key):
- """
- Return the value corresponding to ``key``.
- """
- val = self.__map[key]
- if hasattr(val, 'get_value'):
- return val.get_value()
- else:
- return val
-
- def __setitem__(self, key, value):
- """
- Set the item at ``key`` to ``value``.
- """
- if key in self or hasattr(self, key):
- raise AttributeError('cannot overwrite %s.%s' %
- (self.__class__.__name__, key)
- )
- self.__map[key] = value
-
- def __contains__(self, key):
- """
- Return True if instance contains ``key``; otherwise return False.
- """
- return key in self.__map
-
- def __iter__(self):
- """
- Iterate through keys in ascending order.
- """
- for key in sorted(self.__map):
- yield key
-
- def update(self, new_vals, ignore_errors = False):
- assert type(new_vals) == dict
- for key, value in new_vals.iteritems():
- if key in self and ignore_errors:
- continue
- self[key] = value
-
- def get(self, name, default=None):
- return self.__map.get(name, default)
-
class API(DictProxy):
"""
Dynamic API object through which `Plugin` instances are accessed.