From f104c8de0e9d892f65dc99eafd3b657c3e98dc32 Mon Sep 17 00:00:00 2001 From: Ted Ross Date: Tue, 11 Jan 2011 19:24:14 +0000 Subject: Added argument/type check for output arguments on methods. git-svn-id: https://svn.apache.org/repos/asf/qpid/trunk/qpid@1057814 13f79535-47bb-0310-9956-ffa450edef68 --- cpp/src/qmf/AgentSession.cpp | 11 +++++++---- 1 file changed, 7 insertions(+), 4 deletions(-) (limited to 'cpp/src/qmf/AgentSession.cpp') diff --git a/cpp/src/qmf/AgentSession.cpp b/cpp/src/qmf/AgentSession.cpp index 3426167f87..d8600fc3c0 100644 --- a/cpp/src/qmf/AgentSession.cpp +++ b/cpp/src/qmf/AgentSession.cpp @@ -650,16 +650,19 @@ void AgentSessionImpl::handleMethodRequest(const Variant::Map& content, const Me return; } - if (DataImplAccess::get(iter->second).getSchema().isValid()) + Schema schema(DataImplAccess::get(iter->second).getSchema()); + if (schema.isValid()) { + eventImpl->setSchema(schema); for (Variant::Map::const_iterator aIter = eventImpl->getArguments().begin(); aIter != eventImpl->getArguments().end(); aIter++) { const Schema& schema(DataImplAccess::get(iter->second).getSchema()); if (!SchemaImplAccess::get(schema).isValidMethodInArg(eventImpl->getMethodName(), aIter->first, aIter->second)) { - AgentEvent event(eventImpl.release()); - raiseException(event, "Invalid argument: " + aIter->first); - return; + AgentEvent event(eventImpl.release()); + raiseException(event, "Invalid argument: " + aIter->first); + return; } } + } } enqueueEvent(AgentEvent(eventImpl.release())); -- cgit v1.2.1