summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorJason Gerard DeRose <jderose@redhat.com>2008-07-19 21:51:07 +0000
committerJason Gerard DeRose <jderose@redhat.com>2008-07-19 21:51:07 +0000
commite76160b01db52f9e750a605983eb85ae97305629 (patch)
tree626e09c3761c7ad975d0aa56dcbf32f2fbd23e9c
parent26c9f4c8818e9904dab838ac95839c0d527219b8 (diff)
downloadfreeipa-e76160b01db52f9e750a605983eb85ae97305629.tar.gz
freeipa-e76160b01db52f9e750a605983eb85ae97305629.tar.xz
freeipa-e76160b01db52f9e750a605983eb85ae97305629.zip
8: Experimental work on more OO definition of what gets pluged into API.commands
-rw-r--r--ipalib/base.py8
-rw-r--r--ipalib/crud.py83
-rw-r--r--ipalib/identity.py54
-rw-r--r--ipalib/tests/test_crud.py111
4 files changed, 254 insertions, 2 deletions
diff --git a/ipalib/base.py b/ipalib/base.py
index 51324f938..62949eef5 100644
--- a/ipalib/base.py
+++ b/ipalib/base.py
@@ -101,7 +101,7 @@ class NameSpace(object):
__locked = False # Whether __setattr__ has been locked
- def __init__(self, kw):
+ def __init__(self, kw, order=None):
"""
The single constructor argument `kw` is a dict of the (key, value)
pairs to be in this NameSpace instance.
@@ -111,7 +111,11 @@ class NameSpace(object):
for (key, value) in self.__kw.items():
assert not key.startswith('_')
setattr(self, key, value)
- self.__keys = sorted(self.__kw)
+ if order is None:
+ self.__keys = sorted(self.__kw)
+ else:
+ self.__keys = list(order)
+ assert set(self.__keys) == set(self.__kw)
self.__locked = True
def __setattr__(self, name, value):
diff --git a/ipalib/crud.py b/ipalib/crud.py
new file mode 100644
index 000000000..1be727673
--- /dev/null
+++ b/ipalib/crud.py
@@ -0,0 +1,83 @@
+# Authors:
+# Jason Gerard DeRose <jderose@redhat.com>
+#
+# Copyright (C) 2008 Red Hat
+# see file 'COPYING' for use and warranty information
+#
+# 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 2 only
+#
+# 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
+
+"""
+
+"""
+
+from base import NameSpace
+
+class Named(object):
+ def __get_name(self):
+ return self.__class__.__name__
+ name = property(__get_name)
+
+class ObjectMember(Named):
+ def __init__(self, obj):
+ self.__obj = obj
+
+ def __get_obj(self):
+ return self.__obj
+ obj = property(__get_obj)
+
+
+class Command(ObjectMember):
+ def __get_full_name(self):
+ return '%s_%s' % (self.name, self.obj.name)
+ full_name = property(__get_full_name)
+
+class Attribute(ObjectMember):
+ def __get_full_name(self):
+ return '%s_%s' % (self.obj.name, self.name)
+ full_name = property(__get_full_name)
+
+
+class Object(Named):
+ def __init__(self):
+ self.__commands = self.__build_ns(self.get_commands)
+ self.__attributes = self.__build_ns(self.get_attributes, True)
+
+ def __get_commands(self):
+ return self.__commands
+ commands = property(__get_commands)
+
+ def __get_attributes(self):
+ return self.__attributes
+ attributes = property(__get_attributes)
+
+ def __build_ns(self, callback, preserve=False):
+ d = {}
+ o = []
+ for cls in callback():
+ i = cls(self)
+ assert i.name not in d
+ d[i.name] = i
+ o.append(i.name)
+ if preserve:
+ return NameSpace(d, order=o)
+ return NameSpace(d)
+
+ def __get_commands(self):
+ return
+
+ def get_commands(self):
+ raise NotImplementedError
+
+ def get_attributes(self):
+ raise NotImplementedError
diff --git a/ipalib/identity.py b/ipalib/identity.py
new file mode 100644
index 000000000..00caa20b4
--- /dev/null
+++ b/ipalib/identity.py
@@ -0,0 +1,54 @@
+# hidden
+# read only
+# editable
+
+
+
+
+ def get_label(self, _):
+ return _('Title') # Enum?
+
+ def get_label(self, _):
+ return _('First Name')
+
+ def get_label(self, _):
+ return _('Last Name')
+
+ def get_label(self, _):
+ return _('Full Name') # Autofill
+
+ def get_label(self, _):
+ return _('Display Name') # Autofill
+
+ def get_label(self, _):
+ return _('Initials') # generated/ro?
+
+ def get_label(self, _):
+ return _('Account Status') # Enum (active, inactive)
+
+ def get_label(self, _):
+ return _('Login')
+
+ def get_label(self, _):
+ return _('Password')
+
+ def get_label(self, _): # Same field as above, special interface
+ return _('Confirm Password')
+
+ def get_label(self, _):
+ return _('UID') #ro
+
+ def get_label(self, _):
+ return _('GID') #ro
+
+ def get_label(self, _):
+ return _('Home Directory') #ro
+
+ def get_label(self, _):
+ return _('Login Shell')
+
+ def get_label(self, _):
+ return _('GECOS')
+
+ def get_label(self, _):
+ return _('')
diff --git a/ipalib/tests/test_crud.py b/ipalib/tests/test_crud.py
new file mode 100644
index 000000000..12ee1009b
--- /dev/null
+++ b/ipalib/tests/test_crud.py
@@ -0,0 +1,111 @@
+# Authors:
+# Jason Gerard DeRose <jderose@redhat.com>
+#
+# Copyright (C) 2008 Red Hat
+# see file 'COPYING' for use and warranty information
+#
+# 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 2 only
+#
+# 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
+
+"""
+Unit tests for `ipalib.crud` module.
+"""
+
+from ipalib import crud, base, exceptions
+
+class create(crud.Command):
+ pass
+
+class retrieve(crud.Command):
+ pass
+
+class update(crud.Command):
+ pass
+
+class delete(crud.Command):
+ pass
+
+class givenName(crud.Attribute):
+ pass
+
+class sn(crud.Attribute):
+ pass
+
+class login(crud.Attribute):
+ pass
+
+
+class user(crud.Object):
+ def get_commands(self):
+ return [
+ create,
+ retrieve,
+ update,
+ delete,
+ ]
+
+ def get_attributes(self):
+ return [
+ givenName,
+ sn,
+ login,
+ ]
+
+
+def test_Named():
+ class named_class(crud.Named):
+ pass
+
+ n = named_class()
+ assert n.name == 'named_class'
+
+
+def test_Command():
+ class user(object):
+ name = 'user'
+ class add(crud.Command):
+ pass
+ i = add(user())
+ assert i.name == 'add'
+ assert i.full_name == 'add_user'
+
+
+def test_Object():
+ i = user()
+ assert i.name == 'user'
+
+ # Test commands:
+ commands = i.commands
+ assert isinstance(commands, base.NameSpace)
+ assert list(commands) == ['create', 'delete', 'retrieve', 'update']
+ assert len(commands) == 4
+ for name in commands:
+ cls = globals()[name]
+ cmd = commands[name]
+ assert type(cmd) is cls
+ assert getattr(commands, name) is cmd
+ assert cmd.name == name
+ assert cmd.full_name == ('%s_user' % name)
+
+ # Test attributes:
+ attributes = i.attributes
+ assert isinstance(attributes, base.NameSpace)
+ assert list(attributes) == ['givenName', 'sn', 'login']
+ assert len(attributes) == 3
+ for name in attributes:
+ cls = globals()[name]
+ attr = attributes[name]
+ assert type(attr) is cls
+ assert getattr(attributes, name) is attr
+ assert attr.name == name
+ assert attr.full_name == ('user_%s' % name)