(file) Return to CIMOperationResponseEncoder.cpp CVS log (file) (dir) Up to [Pegasus] / pegasus / src / Pegasus / Server

File: [Pegasus] / pegasus / src / Pegasus / Server / CIMOperationResponseEncoder.cpp (download)
Revision: 1.68, Tue Sep 26 20:52:56 2006 UTC (17 years, 9 months ago) by denise.eckstein
Branch: MAIN
CVS Tags: TASK-TASK-BUG4011_WinLocalConnect-branch-New-root, TASK-TASK-BUG4011_WinLocalConnect-branch-New-merged_out_to_branch, TASK-TASK-BUG4011_WinLocalConnect-branch-New-merged_out_from_trunk, TASK-TASK-BUG4011_WinLocalConnect-branch-New-merged_in_to_trunk, TASK-TASK-BUG4011_WinLocalConnect-branch-New-merged_in_from_branch, TASK-TASK-BUG4011_WinLocalConnect-branch-New-branch, TASK-PEP268_SSLClientCertificatePropagation-root, TASK-PEP268_SSLClientCertificatePropagation-merged_out_to_branch, TASK-PEP268_SSLClientCertificatePropagation-merged_out_from_trunk, TASK-PEP268_SSLClientCertificatePropagation-merged_in_to_trunk, TASK-PEP268_SSLClientCertificatePropagation-merged_in_from_branch, TASK-PEP268_SSLClientCertificatePropagation-branch, TASK-PEP267_SLPReregistrationSupport-root, TASK-PEP267_SLPReregistrationSupport-merging_out_to_branch, TASK-PEP267_SLPReregistrationSupport-merging_out_from_trunk, TASK-PEP267_SLPReregistrationSupport-merged_out_to_branch, TASK-PEP267_SLPReregistrationSupport-merged_out_from_trunk, TASK-PEP267_SLPReregistrationSupport-merged_in_to_trunk, TASK-PEP267_SLPReregistrationSupport-merged_in_from_branch, TASK-PEP267_SLPReregistrationSupport-branch, TASK-Bugs5690_3913_RemoteCMPI-root, TASK-Bugs5690_3913_RemoteCMPI-merged_out_to_branch, TASK-Bugs5690_3913_RemoteCMPI-merged_out_from_trunk, TASK-Bugs5690_3913_RemoteCMPI-merged_in_to_trunk, TASK-Bugs5690_3913_RemoteCMPI-merged_in_from_branch, TASK-Bugs5690_3913_RemoteCMPI-branch, TASK-Bug2021_RemoteCMPIonWindows-root, TASK-Bug2021_RemoteCMPIonWindows-merged_out_to_branch, TASK-Bug2021_RemoteCMPIonWindows-merged_out_from_trunk, TASK-Bug2021_RemoteCMPIonWindows-merged_in_to_trunk, TASK-Bug2021_RemoteCMPIonWindows-merged_in_from_branch, TASK-Bug2021_RemoteCMPIonWindows-branch, TASK-Bug2021_RCMPIonWindows-root, TASK-Bug2021_RCMPIonWindows-merged_out_to_branch, TASK-Bug2021_RCMPIonWindows-merged_out_from_trunk, TASK-Bug2021_RCMPIonWindows-merged_in_to_trunk, TASK-Bug2021_RCMPIonWindows-merged_in_from_branch, TASK-Bug2021_RCMPIonWindows-branch, TASK-BUG4011_WinLocalConnect-branch-New, RELEASE_2_6_0-FC
Changes since 1.67: +4 -1 lines
BUG#:5605
TITLE: Compile failure with PEGASUS_DISABLE_PERFINST defined

DESCRIPTION: getTotalServerTime should only be called if PEGASUS_DISABLE_PERFINST is not defined.

//%2006////////////////////////////////////////////////////////////////////////
//
// Copyright (c) 2000, 2001, 2002 BMC Software; Hewlett-Packard Development
// Company, L.P.; IBM Corp.; The Open Group; Tivoli Systems.
// Copyright (c) 2003 BMC Software; Hewlett-Packard Development Company, L.P.;
// IBM Corp.; EMC Corporation, The Open Group.
// Copyright (c) 2004 BMC Software; Hewlett-Packard Development Company, L.P.;
// IBM Corp.; EMC Corporation; VERITAS Software Corporation; The Open Group.
// Copyright (c) 2005 Hewlett-Packard Development Company, L.P.; IBM Corp.;
// EMC Corporation; VERITAS Software Corporation; The Open Group.
// Copyright (c) 2006 Hewlett-Packard Development Company, L.P.; IBM Corp.;
// EMC Corporation; Symantec Corporation; The Open Group.
//
// Permission is hereby granted, free of charge, to any person obtaining a copy
// of this software and associated documentation files (the "Software"), to
// deal in the Software without restriction, including without limitation the
// rights to use, copy, modify, merge, publish, distribute, sublicense, and/or
// sell copies of the Software, and to permit persons to whom the Software is
// furnished to do so, subject to the following conditions:
// 
// THE ABOVE COPYRIGHT NOTICE AND THIS PERMISSION NOTICE SHALL BE INCLUDED IN
// ALL COPIES OR SUBSTANTIAL PORTIONS OF THE SOFTWARE. THE SOFTWARE IS PROVIDED
// "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR IMPLIED, INCLUDING BUT NOT
// LIMITED TO THE WARRANTIES OF MERCHANTABILITY, FITNESS FOR A PARTICULAR
// PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT
// HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN
// ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION
// WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE.
//
//==============================================================================
//
// Author: Mike Brasher (mbrasher@bmc.com)
//
// Modified By: Yi Zhou (yi_zhou@hp.com)
//              Nitin Upasani, Hewlett-Packard Company (Nitin_Upasani@hp.com)
//              Roger Kumpf, Hewlett-Packard Company (roger_kumpf@hp.com)
//              Arthur Pichlkostner (via Markus: sedgewick_de@yahoo.de)
//              Carol Ann Krug Graves, Hewlett-Packard Company
//                (carolann_graves@hp.com)
//              Sushma Fernandes , Hewlett-Packard Company
//                (sushma_fernandes@hp.com)
//              Dave Rosckes (rosckes@us.ibm.com)
//              Amit K Arora, IBM (amita@in.ibm.com) for PEP#101
//              Seema Gupta (gseema@in.ibm.com) for PEP135
//         Brian G. Campbell, EMC (campbell_brian@emc.com) - PEP140/phase1
//				Willis White (whiwill@us.ibm.com) PEP 127 and 128
//         Brian G. Campbell, EMC (campbell_brian@emc.com) - PEP140/phase2
//              David Dillard, VERITAS Software Corp.
//                 (david.dillard@veritas.com)
//              John Alex, IBM (johnalex@us.ibm.com) - Bug#2290
//
//%/////////////////////////////////////////////////////////////////////////////

#include <Pegasus/Common/Config.h>
#include <Pegasus/Common/Constants.h>
#include <cctype>
#include <cstdio>
#include <Pegasus/Common/HTTPConnection.h>
#include <Pegasus/Common/XmlParser.h>
#include <Pegasus/Common/XmlReader.h>
#include <Pegasus/Common/XmlWriter.h>
#include <Pegasus/Common/HTTPMessage.h>
#include <Pegasus/Common/Logger.h>
#include <Pegasus/Common/Tracer.h>
#include <Pegasus/Common/StatisticalData.h>
#include <Pegasus/Common/AutoPtr.h>
#include "CIMOperationResponseEncoder.h"

// l10n
#include <Pegasus/Common/MessageLoader.h>

PEGASUS_USING_STD;

PEGASUS_NAMESPACE_BEGIN

const String CIMOperationResponseEncoder::OUT_OF_MEMORY_MESSAGE  =
   "A System error has occured. Please retry the CIM Operation at a later time.";

CIMOperationResponseEncoder::CIMOperationResponseEncoder()
   : Base(PEGASUS_QUEUENAME_OPRESPENCODER)
{

}

CIMOperationResponseEncoder::~CIMOperationResponseEncoder()
{

}

void 
CIMOperationResponseEncoder::sendResponse(CIMResponseMessage* response,
																					const String &name,
																					Boolean isImplicit,
																					Buffer *bodygiven)
{
	static String funcname = "CIMOperationResponseEncoder::sendResponse: ";
 	static String funcnameClassS = String(funcname + "for class " + name);
 	static CString funcnameClass = funcnameClassS.getCString();
 	PEG_METHOD_ENTER(TRC_DISPATCHER, funcnameClass);

	if (! response)
	{
		PEG_METHOD_EXIT();
		return;
	}

	Uint32 queueId = response->queueIds.top();
	response->queueIds.pop();

        Boolean closeConnect = response->getCloseConnect();
        Tracer::trace(
            TRC_HTTP,
            Tracer::LEVEL3,
            "CIMOperationResponseEncoder::sendResponse()- response->getCloseConnect() returned %d",
            closeConnect);

	MessageQueue* queue = MessageQueue::lookup(queueId);

	if (!queue)
	{
		Tracer::trace(TRC_DISCARDED_DATA, Tracer::LEVEL2, 
									"ERROR: non-existent queueId = %u, response not sent.", queueId);
		PEG_METHOD_EXIT();
		return;
	}

	HTTPConnection *httpQueue = dynamic_cast<HTTPConnection *>(queue);

	if (! httpQueue)
	{
		Tracer::trace(TRC_DISCARDED_DATA, Tracer::LEVEL2, 
									"ERROR: Unknown queue type. queueId = %u, response not sent.",
									queueId);
		PEG_METHOD_EXIT();
		return;
	}

	Boolean isChunkRequest = httpQueue->isChunkRequested();
	HttpMethod httpMethod = response->getHttpMethod();
	String &messageId = response->messageId;
	CIMException &cimException = response->cimException;
	Buffer message;

	// Note: the language is ALWAYS passed empty to the xml formatters because
	// it is HTTPConnection that needs to make the decision of whether to add
	// the languages to the HTTP message.
	ContentLanguageList contentLanguage;

	CIMName cimName(name);
	Uint32 messageIndex = response->getIndex();
	Boolean isFirst = messageIndex == 0 ? true : false;
	Boolean isLast = response->isComplete();
	Buffer bodylocal;
	Buffer &body = bodygiven ? *bodygiven : bodylocal;

    // STAT_SERVEREND sets the getTotalServerTime() value in the message class
    STAT_SERVEREND

#ifndef PEGASUS_DISABLE_PERFINST
    Uint64 serverTime = response->getTotalServerTime();
#else
    Uint64 serverTime = 0;
#endif

	Buffer (*formatResponse)(const CIMName& iMethodName,
																 const String& messageId,
																 HttpMethod httpMethod,
																 const ContentLanguageList &httpContentLanguages, 
																 const Buffer& body,
																 Uint64 serverResponseTime,
																 Boolean isFirst,
																 Boolean isLast);

	Buffer (*formatError)(const CIMName& methodName,
															const String& messageId,
															HttpMethod httpMethod,
															const CIMException& cimException);

	if (isImplicit == false)
	{
		formatResponse = XmlWriter::formatSimpleMethodRspMessage;
		formatError = XmlWriter::formatSimpleMethodErrorRspMessage;
	}
	else
	{
		formatResponse = XmlWriter::formatSimpleIMethodRspMessage;
 		formatError = XmlWriter::formatSimpleIMethodErrorRspMessage;
	}

	if (cimException.getCode() != CIM_ERR_SUCCESS)
	{
		STAT_SERVEREND_ERROR

		// only process the FIRST error
		if (httpQueue->cimException.getCode() == CIM_ERR_SUCCESS)
		{
			// NOTE: even if this error occurs in the middle, HTTPConnection will
			// flush the entire queued message and reformat.
			if (isChunkRequest == false)
				message = formatError(name, messageId, httpMethod, cimException);

			// uri encode the error (for the http header) only when it is 
			// non-chunking or the first error with chunking
			if (isChunkRequest == false || (isChunkRequest == true && isFirst == true))
			{
				String msg = TraceableCIMException(cimException).getDescription();
				String uriEncodedMsg = XmlWriter::encodeURICharacters(msg);
				CIMException cimExceptionUri(cimException.getCode(), uriEncodedMsg);
				cimExceptionUri.setContentLanguages(cimException.getContentLanguages());
				cimException = cimExceptionUri;
			}

		} // if first error in response stream

		// never put the error in chunked response (because it will end up in
		// the trailer), so just use the non-error response formatter to send
		// more data

		if (isChunkRequest == true)
		{
			message = formatResponse(cimName, messageId, httpMethod, contentLanguage,
															 body, serverTime, isFirst, isLast);
		}
	}
	else
	{
		// else non-error condition
	  	try
		{
			message = formatResponse(cimName, messageId, httpMethod, contentLanguage,
															 body, serverTime, isFirst, isLast);
		}

#ifdef PEGASUS_PLATFORM_WIN32_IX86_MSVC
   catch (std::bad_alloc&)
#else
   catch (bad_alloc&)
#endif
	 {
		 Logger::put(Logger::STANDARD_LOG, System::CIMSERVER, Logger::TRACE,
								 funcname + OUT_OF_MEMORY_MESSAGE);

		 cimException = PEGASUS_CIM_EXCEPTION_L
			 (CIM_ERR_FAILED,
				MessageLoaderParms("Server.CIMOperationResponseEncoder.OUT_OF_MEMORY", 
													 OUT_OF_MEMORY_MESSAGE));
		 // try again with new error and no body
		 body.clear();
		 sendResponse(response, name, isImplicit);
		 return;
	 }
	 
	 STAT_BYTESSENT

	}

	AutoPtr<HTTPMessage> httpMessage(new HTTPMessage(message, 0, &cimException));
	httpMessage->setComplete(isLast);
	httpMessage->setIndex(messageIndex);

	if (cimException.getCode() != CIM_ERR_SUCCESS)
	{
		httpMessage->contentLanguages = cimException.getContentLanguages();
	}
	else
	{
		const OperationContext::Container &container = 
			response->operationContext.get(ContentLanguageListContainer::NAME);
		const ContentLanguageListContainer &listContainer =
			*dynamic_cast<const ContentLanguageListContainer *>(&container);
		contentLanguage = listContainer.getLanguages();
		httpMessage->contentLanguages = contentLanguage;
	}

        Tracer::traceBuffer(
            TRC_XML_IO,
            Tracer::LEVEL2,
            httpMessage->message.getData(),
            httpMessage->message.size());
	
        PEG_LOGGER_TRACE((
            Logger::STANDARD_LOG,
            System::CIMSERVER,
            Logger::TRACE,
            "CIMOperationResponseEncoder::sendResponse - QueueId: $0  "
            "XML content: $1",queueId,
            String(message.getData(), message.size())));
	
        httpMessage->setCloseConnect(closeConnect);
	queue->enqueue(httpMessage.release());
	
	PEG_METHOD_EXIT();	
}

void CIMOperationResponseEncoder::enqueue(Message *message)
{
    handleEnqueue(message);
}

void CIMOperationResponseEncoder::handleEnqueue(Message *message)
{
   PEG_METHOD_ENTER(TRC_DISPATCHER,
                    "CIMOperationResponseEncoder::handleEnqueue()");

   if (!message)
   {
      PEG_METHOD_EXIT();
      return;
   }

   Tracer::trace(
       TRC_HTTP,
       Tracer::LEVEL3,
       "CIMOperationResponseEncoder::handleEnque()- message->getCloseConnect() returned %d",
       message->getCloseConnect());

   
   switch (message->getType())
   {
      case CIM_GET_CLASS_RESPONSE_MESSAGE:
	 encodeGetClassResponse(
	    (CIMGetClassResponseMessage*)message);
	 break;

      case CIM_GET_INSTANCE_RESPONSE_MESSAGE:
	 encodeGetInstanceResponse(
	    (CIMGetInstanceResponseMessage*)message);
	 break;

      case CIM_DELETE_CLASS_RESPONSE_MESSAGE:
	 encodeDeleteClassResponse(
	    (CIMDeleteClassResponseMessage*)message);
	 break;

      case CIM_DELETE_INSTANCE_RESPONSE_MESSAGE:
	 encodeDeleteInstanceResponse(
	    (CIMDeleteInstanceResponseMessage*)message);
	 break;

      case CIM_CREATE_CLASS_RESPONSE_MESSAGE:
	 encodeCreateClassResponse(
	    (CIMCreateClassResponseMessage*)message);
	 break;

      case CIM_CREATE_INSTANCE_RESPONSE_MESSAGE:
	 encodeCreateInstanceResponse(
	    (CIMCreateInstanceResponseMessage*)message);
	 break;

      case CIM_MODIFY_CLASS_RESPONSE_MESSAGE:
	 encodeModifyClassResponse(
	    (CIMModifyClassResponseMessage*)message);
	 break;

      case CIM_MODIFY_INSTANCE_RESPONSE_MESSAGE:
	 encodeModifyInstanceResponse(
	    (CIMModifyInstanceResponseMessage*)message);
	 break;

      case CIM_ENUMERATE_CLASSES_RESPONSE_MESSAGE:
	 encodeEnumerateClassesResponse(
	    (CIMEnumerateClassesResponseMessage*)message);
	 break;

      case CIM_ENUMERATE_CLASS_NAMES_RESPONSE_MESSAGE:
	 encodeEnumerateClassNamesResponse(
	    (CIMEnumerateClassNamesResponseMessage*)message);
	 break;

      case CIM_ENUMERATE_INSTANCES_RESPONSE_MESSAGE:
	 encodeEnumerateInstancesResponse(
	    (CIMEnumerateInstancesResponseMessage*)message);
	 break;

      case CIM_ENUMERATE_INSTANCE_NAMES_RESPONSE_MESSAGE:
	 encodeEnumerateInstanceNamesResponse(
	    (CIMEnumerateInstanceNamesResponseMessage*)message);
	 break;

      case CIM_EXEC_QUERY_RESPONSE_MESSAGE:
	 encodeExecQueryResponse(
	    (CIMExecQueryResponseMessage*)message);
	 break;

      case CIM_ASSOCIATORS_RESPONSE_MESSAGE:
	 encodeAssociatorsResponse(
	    (CIMAssociatorsResponseMessage*)message);
	 break;

      case CIM_ASSOCIATOR_NAMES_RESPONSE_MESSAGE:
	 encodeAssociatorNamesResponse(
	    (CIMAssociatorNamesResponseMessage*)message);
	 break;

      case CIM_REFERENCES_RESPONSE_MESSAGE:
	 encodeReferencesResponse(
	    (CIMReferencesResponseMessage*)message);
	 break;

      case CIM_REFERENCE_NAMES_RESPONSE_MESSAGE:
	 encodeReferenceNamesResponse(
	    (CIMReferenceNamesResponseMessage*)message);
	 break;

      case CIM_GET_PROPERTY_RESPONSE_MESSAGE:
	 encodeGetPropertyResponse(
	    (CIMGetPropertyResponseMessage*)message);
	 break;

      case CIM_SET_PROPERTY_RESPONSE_MESSAGE:
	 encodeSetPropertyResponse(
	    (CIMSetPropertyResponseMessage*)message);
	 break;

      case CIM_GET_QUALIFIER_RESPONSE_MESSAGE:
	 encodeGetQualifierResponse(
	    (CIMGetQualifierResponseMessage*)message);
	 break;

      case CIM_SET_QUALIFIER_RESPONSE_MESSAGE:
	 encodeSetQualifierResponse(
	    (CIMSetQualifierResponseMessage*)message);
	 break;

      case CIM_DELETE_QUALIFIER_RESPONSE_MESSAGE:
	 encodeDeleteQualifierResponse(
	    (CIMDeleteQualifierResponseMessage*)message);
	 break;

      case CIM_ENUMERATE_QUALIFIERS_RESPONSE_MESSAGE:
	 encodeEnumerateQualifiersResponse(
	    (CIMEnumerateQualifiersResponseMessage*)message);
	 break;

      case CIM_INVOKE_METHOD_RESPONSE_MESSAGE:
	 encodeInvokeMethodResponse(
	    (CIMInvokeMethodResponseMessage*)message); 
	 break;
   }

	 delete message;

   PEG_METHOD_EXIT();
    
   return;
    
}


void CIMOperationResponseEncoder::handleEnqueue()
{

   Message* message = dequeue();
   if(message)
      handleEnqueue(message);
}

// l10n - added content language support below

void CIMOperationResponseEncoder::encodeCreateClassResponse(
   CIMCreateClassResponseMessage* response)
{
	sendResponse(response, "CreateClass", true);
}

void CIMOperationResponseEncoder::encodeGetClassResponse(
   CIMGetClassResponseMessage* response)
{
	Buffer body;
	if (response->cimException.getCode() == CIM_ERR_SUCCESS)
		XmlWriter::appendClassElement(body, response->cimClass);
	sendResponse(response, "GetClass", true, &body);
}

void CIMOperationResponseEncoder::encodeModifyClassResponse(
   CIMModifyClassResponseMessage* response)
{
	sendResponse(response, "ModifyClass", true);
}

void CIMOperationResponseEncoder::encodeEnumerateClassNamesResponse(
   CIMEnumerateClassNamesResponseMessage* response)
{
	Buffer body;
	if (response->cimException.getCode() == CIM_ERR_SUCCESS)
		for (Uint32 i = 0, n = response->classNames.size(); i < n; i++)
			XmlWriter::appendClassNameElement(body, response->classNames[i]);
	sendResponse(response, "EnumerateClassNames", true, &body);
}

void CIMOperationResponseEncoder::encodeEnumerateClassesResponse(
   CIMEnumerateClassesResponseMessage* response)
{
	Buffer body;
	if (response->cimException.getCode() == CIM_ERR_SUCCESS)
		for (Uint32 i = 0, n= response->cimClasses.size(); i < n; i++)
			XmlWriter::appendClassElement(body, response->cimClasses[i]);
	sendResponse(response, "EnumerateClasses", true, &body);
}

void CIMOperationResponseEncoder::encodeDeleteClassResponse(
   CIMDeleteClassResponseMessage* response)
{
	sendResponse(response, "DeleteClass", true);
}

void CIMOperationResponseEncoder::encodeCreateInstanceResponse(
   CIMCreateInstanceResponseMessage* response)
{
   Buffer body;
	 if (response->cimException.getCode() == CIM_ERR_SUCCESS)
		 XmlWriter::appendInstanceNameElement(body, response->instanceName);
	 sendResponse(response, "CreateInstance", true, &body);
}

void CIMOperationResponseEncoder::encodeGetInstanceResponse(
   CIMGetInstanceResponseMessage* response)
{
   Buffer body;
	 if (response->cimException.getCode() == CIM_ERR_SUCCESS)
		 XmlWriter::appendInstanceElement(body, response->cimInstance);
	 sendResponse(response, "GetInstance", true, &body);
}

void CIMOperationResponseEncoder::encodeModifyInstanceResponse(
   CIMModifyInstanceResponseMessage* response)
{
	sendResponse(response, "ModifyInstance", true);
}

void CIMOperationResponseEncoder::encodeEnumerateInstancesResponse(
   CIMEnumerateInstancesResponseMessage* response)
{
	Buffer body;
	if (response->cimException.getCode() == CIM_ERR_SUCCESS)
		for (Uint32 i = 0, n = response->cimNamedInstances.size(); i < n; i++)
			XmlWriter::appendValueNamedInstanceElement(body, response->cimNamedInstances[i]);
	sendResponse(response, "EnumerateInstances", true, &body);
}

void CIMOperationResponseEncoder::encodeEnumerateInstanceNamesResponse(
   CIMEnumerateInstanceNamesResponseMessage* response)
{
   Buffer body;
	 if (response->cimException.getCode() == CIM_ERR_SUCCESS)
		 for (Uint32 i = 0, n = response->instanceNames.size(); i < n; i++)
			 XmlWriter::appendInstanceNameElement(body, response->instanceNames[i]);
	 sendResponse(response, "EnumerateInstanceNames", true, &body);
}

void CIMOperationResponseEncoder::encodeDeleteInstanceResponse(
   CIMDeleteInstanceResponseMessage* response)
{
	sendResponse(response, "DeleteInstance", true);
}

void CIMOperationResponseEncoder::encodeGetPropertyResponse(
   CIMGetPropertyResponseMessage* response)
{
	Buffer body;
	if (response->cimException.getCode() == CIM_ERR_SUCCESS)
		XmlWriter::appendValueElement(body, response->value);
	sendResponse(response, "GetProperty", true, &body);
}

void CIMOperationResponseEncoder::encodeSetPropertyResponse(
   CIMSetPropertyResponseMessage* response)
{
	sendResponse(response, "SetProperty", true);
}

void CIMOperationResponseEncoder::encodeSetQualifierResponse(
   CIMSetQualifierResponseMessage* response)
{
	sendResponse(response, "SetQualifier", true);
}

void CIMOperationResponseEncoder::encodeGetQualifierResponse(
   CIMGetQualifierResponseMessage* response)
{
	Buffer body;
	if (response->cimException.getCode() == CIM_ERR_SUCCESS)
		XmlWriter::appendQualifierDeclElement(body, response->cimQualifierDecl);
	sendResponse(response, "GetQualifier", true, &body);
}

void CIMOperationResponseEncoder::encodeEnumerateQualifiersResponse(
   CIMEnumerateQualifiersResponseMessage* response)
{
   Buffer body;
	 if (response->cimException.getCode() == CIM_ERR_SUCCESS)
		 for (Uint32 i = 0, n = response->qualifierDeclarations.size(); i < n;i++)
			 XmlWriter::appendQualifierDeclElement(body, response->qualifierDeclarations[i]);
	 sendResponse(response, "EnumerateQualifiers", true, &body);
}

void CIMOperationResponseEncoder::encodeDeleteQualifierResponse(
   CIMDeleteQualifierResponseMessage* response)
{
	sendResponse(response, "DeleteQualifier", true);
}

void CIMOperationResponseEncoder::encodeReferenceNamesResponse(
   CIMReferenceNamesResponseMessage* response)
{
   Buffer body;
	 if (response->cimException.getCode() == CIM_ERR_SUCCESS)
		 for (Uint32 i = 0, n = response->objectNames.size(); i < n; i++)
		 {
			 body << "<OBJECTPATH>\n";
			 XmlWriter::appendValueReferenceElement(body, response->objectNames[i],
																							false);
			 body << "</OBJECTPATH>\n";
		 }
	 sendResponse(response, "ReferenceNames", true, &body);
}

void CIMOperationResponseEncoder::encodeReferencesResponse(
   CIMReferencesResponseMessage* response)
{
   Buffer body;
	 if (response->cimException.getCode() == CIM_ERR_SUCCESS)
		 for (Uint32 i = 0, n = response->cimObjects.size(); i < n;i++)
			 XmlWriter::appendValueObjectWithPathElement(body, response->cimObjects[i]);
	 sendResponse(response, "References", true, &body);
}

void CIMOperationResponseEncoder::encodeAssociatorNamesResponse(
   CIMAssociatorNamesResponseMessage* response)
{
   Buffer body;
	 if (response->cimException.getCode() == CIM_ERR_SUCCESS)
		 for (Uint32 i = 0, n = response->objectNames.size(); i < n; i++)
		 {
			 body << "<OBJECTPATH>\n";
			 XmlWriter::appendValueReferenceElement(body, response->objectNames[i], false);
			 body << "</OBJECTPATH>\n";
		 }
	 sendResponse(response, "AssociatorNames", true, &body);
}

void CIMOperationResponseEncoder::encodeAssociatorsResponse(
   CIMAssociatorsResponseMessage* response)
{
   Buffer body;
	 if (response->cimException.getCode() == CIM_ERR_SUCCESS)
		 for (Uint32 i = 0, n = response->cimObjects.size(); i < n; i++)
			 XmlWriter::appendValueObjectWithPathElement(body, response->cimObjects[i]);
	 sendResponse(response, "Associators", true, &body);
}

void CIMOperationResponseEncoder::encodeExecQueryResponse(
   CIMExecQueryResponseMessage* response)
{
   Buffer body;
	 if (response->cimException.getCode() == CIM_ERR_SUCCESS)
		 for (Uint32 i = 0; i < response->cimObjects.size(); i++)
			 XmlWriter::appendValueObjectWithPathElement(body, response->cimObjects[i]);
	 sendResponse(response, "ExecQuery", true, &body);
}

void CIMOperationResponseEncoder::encodeInvokeMethodResponse(
    CIMInvokeMethodResponseMessage* response)
{
   Buffer body;

   // ATTN-RK-P3-20020219: Who's job is it to make sure the return value is
   // not an array?
   // Only add the return value if it is not null

	 if (response->cimException.getCode() == CIM_ERR_SUCCESS)
	 {
		 if (!response->retValue.isNull())
			 XmlWriter::appendReturnValueElement(body, response->retValue);
		 
		 for (Uint32 i=0, n = response->outParameters.size(); i < n; i++)
			 XmlWriter::appendParamValueElement(body, response->outParameters[i]);
	 }
	 sendResponse(response, response->methodName.getString(), false, &body);
}

PEGASUS_NAMESPACE_END

No CVS admin address has been configured
Powered by
ViewCVS 0.9.2