summaryrefslogtreecommitdiffstats
path: root/ipa_server
diff options
context:
space:
mode:
authorRob Crittenden <rcritten@redhat.com>2008-10-17 19:20:23 -0400
committerRob Crittenden <rcritten@redhat.com>2008-10-17 19:20:23 -0400
commitae8370be44d95b9f6793ded46ef81126aebef3e0 (patch)
tree22598861258663bc81ff53b0c2576a0b70faab15 /ipa_server
parente66cd9599bb8eef124a6c890b9a1ae471b3b937f (diff)
downloadfreeipa-ae8370be44d95b9f6793ded46ef81126aebef3e0.tar.gz
freeipa-ae8370be44d95b9f6793ded46ef81126aebef3e0.tar.xz
freeipa-ae8370be44d95b9f6793ded46ef81126aebef3e0.zip
Port f_service to LDAP backend
Add new keyword, 'filter', that can be passed to the search function. This is globbed onto the filter that is auto-created.
Diffstat (limited to 'ipa_server')
-rw-r--r--ipa_server/plugins/b_ldap.py21
1 files changed, 19 insertions, 2 deletions
diff --git a/ipa_server/plugins/b_ldap.py b/ipa_server/plugins/b_ldap.py
index bc1f8951c..4845a5993 100644
--- a/ipa_server/plugins/b_ldap.py
+++ b/ipa_server/plugins/b_ldap.py
@@ -50,7 +50,7 @@ class ldap(CrudBackend):
def make_group_dn(self, cn):
"""
- Construct user dn from cn.
+ Construct group dn from cn.
"""
return 'cn=%s,%s,%s' % (
self.dn.escape_dn_chars(cn),
@@ -58,17 +58,28 @@ class ldap(CrudBackend):
self.api.env.basedn,
)
+ def make_service_dn(self, principal):
+ """
+ Construct service principal dn from principal name
+ """
+ return 'krbprincipalname=%s,%s,%s' % (
+ self.dn.escape_dn_chars(principal),
+ self.api.env.container_service,
+ self.api.env.basedn,
+ )
+
def get_object_type(self, attribute):
"""
Based on attribute, make an educated guess as to the type of
object we're looking for.
"""
+ attribute = attribute.lower()
object_type = None
if attribute == "uid": # User
object_type = "person"
elif attribute == "cn": # Group
object_type = "posixGroup"
- elif attribute == "krbprincipal": # Service
+ elif attribute == "krbprincipalname": # Service
object_type = "krbPrincipal"
return object_type
@@ -168,12 +179,18 @@ class ldap(CrudBackend):
def search(self, **kw):
objectclass = kw.get('objectclass')
+ sfilter = kw.get('filter')
if objectclass:
del kw['objectclass']
+ if sfilter:
+ del kw['filter']
(exact_match_filter, partial_match_filter) = self._generate_search_filters(**kw)
if objectclass:
exact_match_filter = "(&(objectClass=%s)%s)" % (objectclass, exact_match_filter)
partial_match_filter = "(&(objectClass=%s)%s)" % (objectclass, partial_match_filter)
+ if sfilter:
+ exact_match_filter = "(%s%s)" % (sfilter, exact_match_filter)
+ partial_match_filter = "(%s%s)" % (sfilter, partial_match_filter)
search_base = "%s, %s" % (self.api.env.container_accounts, self.api.env.basedn)
try: