diff options
author | Simo Sorce <ssorce@redhat.com> | 2007-08-09 14:52:54 -0400 |
---|---|---|
committer | Simo Sorce <ssorce@redhat.com> | 2007-08-09 14:52:54 -0400 |
commit | a59c36b394dba5f8b371c1a6cdab0317a5507486 (patch) | |
tree | 91cbc96560da1e0aebe3b0dda64c8b3191495a0b /ipa-server/xmlrpc-server/ipaxmlrpc.py | |
parent | 950bddf2a32b765ee97df5442a1ec9c0a358ccb3 (diff) | |
parent | cf93b1bc642a843242cc9aaf585c08c5475ad632 (diff) | |
download | freeipa.git-a59c36b394dba5f8b371c1a6cdab0317a5507486.tar.gz freeipa.git-a59c36b394dba5f8b371c1a6cdab0317a5507486.tar.xz freeipa.git-a59c36b394dba5f8b371c1a6cdab0317a5507486.zip |
merge in changes from upstream
Diffstat (limited to 'ipa-server/xmlrpc-server/ipaxmlrpc.py')
-rw-r--r-- | ipa-server/xmlrpc-server/ipaxmlrpc.py | 17 |
1 files changed, 12 insertions, 5 deletions
diff --git a/ipa-server/xmlrpc-server/ipaxmlrpc.py b/ipa-server/xmlrpc-server/ipaxmlrpc.py index ad5e3068..7bad9ab5 100644 --- a/ipa-server/xmlrpc-server/ipaxmlrpc.py +++ b/ipa-server/xmlrpc-server/ipaxmlrpc.py @@ -123,11 +123,16 @@ class ModXMLRPCRequestHandler(object): def register_instance(self,instance): self.register_module(instance) - def _marshaled_dispatch(self, data): + def _marshaled_dispatch(self, data, remoteuser): """Dispatches an XML-RPC method from marshalled (XML) data.""" params, method = loads(data) + opts={} + opts['remoteuser'] = remoteuser + + params = ipaserver.encode_args(params, opts) + # special case # if method == "get_user": # Marshaller._Marshaller__dump = xmlrpclib_dump @@ -239,7 +244,7 @@ class ModXMLRPCRequestHandler(object): req.allow_methods(['POST'],1) raise apache.SERVER_RETURN, apache.HTTP_METHOD_NOT_ALLOWED - response = self._marshaled_dispatch(req.read()) + response = self._marshaled_dispatch(req.read(), req.user) req.content_type = "text/xml" req.set_content_length(len(response)) @@ -267,10 +272,12 @@ def handler(req, profiling=False): else: opts = req.get_options() try: + f = funcs.IPAServer() h = ModXMLRPCRequestHandler() - h.register_function(funcs.get_user) - h.register_function(funcs.add_user) - h.register_function(funcs.get_add_schema) + h.register_function(f.get_user) + h.register_function(f.add_user) + h.register_function(f.get_add_schema) + h.register_function(f.get_all_users) h.handle_request(req) finally: pass |