summaryrefslogtreecommitdiffstats
path: root/ipa-server/xmlrpc-server
diff options
context:
space:
mode:
authorJohn Dennis <jdennis@redhat.com>2007-11-13 20:05:02 -0500
committerJohn Dennis <jdennis@redhat.com>2007-11-13 20:05:02 -0500
commiteab5a89d4a3e8159348b5a709cd4401c9784f058 (patch)
tree8e7c00a1ea76a348cdacf0f1c4f8ad88d1ae455e /ipa-server/xmlrpc-server
parent152f8e33928d9222257a272fb573aa9ce7d37578 (diff)
downloadfreeipa-eab5a89d4a3e8159348b5a709cd4401c9784f058.tar.gz
freeipa-eab5a89d4a3e8159348b5a709cd4401c9784f058.tar.xz
freeipa-eab5a89d4a3e8159348b5a709cd4401c9784f058.zip
ipa-addradiusclient now working
Diffstat (limited to 'ipa-server/xmlrpc-server')
-rw-r--r--ipa-server/xmlrpc-server/funcs.py22
-rw-r--r--ipa-server/xmlrpc-server/ipaxmlrpc.py1
2 files changed, 20 insertions, 3 deletions
diff --git a/ipa-server/xmlrpc-server/funcs.py b/ipa-server/xmlrpc-server/funcs.py
index 8169b446..7c53e6d0 100644
--- a/ipa-server/xmlrpc-server/funcs.py
+++ b/ipa-server/xmlrpc-server/funcs.py
@@ -456,22 +456,38 @@ class IPAServer:
self.releaseConnection(conn)
return res
+ def __is_radius_client_unique(self, ip_addr, opts):
+ """Return 1 if the radius client is unique in the tree, 0 otherwise."""
+ ip_addr = self.__safe_filter(ip_addr)
+ basedn = 'cn=clients,cn=radius,cn=services,cn=etc,%s' % self.basedn # FIXME, should not be hardcoded
+
+ filter = "(&(radiusClientNASIpAddress=%s)(objectclass=radiusClientProfile))" % ip_addr
+
+ try:
+ entry = self.__get_sub_entry(basedn, filter, ['dn','uid'], opts)
+ return 0
+ except ipaerror.exception_for(ipaerror.LDAP_NOT_FOUND):
+ return 1
+
def add_radius_client (self, client, opts=None):
+ print "add_radius_client:"
client_container = 'cn=clients,cn=radius,cn=services,cn=etc' # FIXME, should not be hardcoded
- if self.__is_client_unique(client['radiusClientNASIpAddress'], opts) == 0:
+ if self.__is_radius_client_unique(client['radiusClientNASIpAddress'], opts) == 0:
raise ipaerror.gen_exception(ipaerror.LDAP_DUPLICATE)
dn="radiusClientNASIpAddress=%s,%s,%s" % (ldap.dn.escape_dn_chars(client['radiusClientNASIpAddress']),
client_container,self.basedn)
- entry = ipaserver.ipaldap.Entry(dn)
- # FIXME: This should be dynamic and can include just about anything
+ print "add_radius_client: dn=%s" % (dn)
+
+ entry = ipaserver.ipaldap.Entry(dn)
# some required objectclasses
entry.setValues('objectClass', 'top', 'radiusClientProfile')
# fill in our new entry with everything sent by the client
for u in client:
+ print "add_radius_client: attr=%s %s" % (u, client[u])
entry.setValues(u, client[u])
conn = self.getConnection(opts)
diff --git a/ipa-server/xmlrpc-server/ipaxmlrpc.py b/ipa-server/xmlrpc-server/ipaxmlrpc.py
index 6aaad117..fe71aec4 100644
--- a/ipa-server/xmlrpc-server/ipaxmlrpc.py
+++ b/ipa-server/xmlrpc-server/ipaxmlrpc.py
@@ -351,6 +351,7 @@ def handler(req, profiling=False):
h.register_function(f.delete_group)
h.register_function(f.attrs_to_labels)
h.register_function(f.group_members)
+ h.register_function(f.add_radius_client)
h.handle_request(req)
finally:
pass