1
0
mirror of https://gitlab.com/libvirt/libvirt.git synced 2025-01-25 10:03:49 +03:00

Set the current client identity during API call dispatch

When dispatching an RPC API call, setup the current identity to
hold the identity of the network client associated with the
RPC message being dispatched. The setting is thread-local, so
only affects the API call in this thread

Signed-off-by: Daniel P. Berrange <berrange@redhat.com>
This commit is contained in:
Daniel P. Berrange 2012-01-23 15:07:15 +00:00
parent d5e83ad9b7
commit ebf78be4c2

View File

@ -375,6 +375,7 @@ virNetServerProgramDispatchCall(virNetServerProgramPtr prog,
virNetServerProgramProcPtr dispatcher; virNetServerProgramProcPtr dispatcher;
virNetMessageError rerr; virNetMessageError rerr;
size_t i; size_t i;
virIdentityPtr identity = NULL;
memset(&rerr, 0, sizeof(rerr)); memset(&rerr, 0, sizeof(rerr));
@ -419,6 +420,12 @@ virNetServerProgramDispatchCall(virNetServerProgramPtr prog,
if (virNetMessageDecodePayload(msg, dispatcher->arg_filter, arg) < 0) if (virNetMessageDecodePayload(msg, dispatcher->arg_filter, arg) < 0)
goto error; goto error;
if (!(identity = virNetServerClientGetIdentity(client)))
goto error;
if (virIdentitySetCurrent(identity) < 0)
goto error;
/* /*
* When the RPC handler is called: * When the RPC handler is called:
* *
@ -431,6 +438,9 @@ virNetServerProgramDispatchCall(virNetServerProgramPtr prog,
*/ */
rv = (dispatcher->func)(server, client, msg, &rerr, arg, ret); rv = (dispatcher->func)(server, client, msg, &rerr, arg, ret);
if (virIdentitySetCurrent(NULL) < 0)
goto error;
/* /*
* If rv == 1, this indicates the dispatch func has * If rv == 1, this indicates the dispatch func has
* populated 'msg' with a list of FDs to return to * populated 'msg' with a list of FDs to return to
@ -481,6 +491,7 @@ virNetServerProgramDispatchCall(virNetServerProgramPtr prog,
VIR_FREE(arg); VIR_FREE(arg);
VIR_FREE(ret); VIR_FREE(ret);
virObjectUnref(identity);
/* Put reply on end of tx queue to send out */ /* Put reply on end of tx queue to send out */
return virNetServerClientSendMessage(client, msg); return virNetServerClientSendMessage(client, msg);
@ -491,6 +502,7 @@ error:
VIR_FREE(arg); VIR_FREE(arg);
VIR_FREE(ret); VIR_FREE(ret);
virObjectUnref(identity);
return rv; return rv;
} }