//%LICENSE//////////////////////////////////////////////////////////////// // // Licensed to The Open Group (TOG) under one or more contributor license // agreements. Refer to the OpenPegasusNOTICE.txt file distributed with // this work for additional information regarding copyright ownership. // Each contributor licenses this file to you under the OpenPegasus Open // Source License; you may not use this file except in compliance with the // License. // // 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. // ////////////////////////////////////////////////////////////////////////// // //%///////////////////////////////////////////////////////////////////////////// #include "CMPI_Version.h" #include "CMPI_String.h" #include "CMPI_Value.h" #include "CMPISCMOUtilities.h" PEGASUS_USING_STD; PEGASUS_NAMESPACE_BEGIN CIMDateTimeRep* CMPISCMOUtilities::scmoDateTimeFromCMPI(CMPIDateTime* cmpidt) { CIMDateTimeRep* cimdt = 0; if (cmpidt && cmpidt->hdl) { cimdt = ((CIMDateTime*)cmpidt->hdl)->_rep; } return cimdt; } // Function to convert a CIMInstance into an SCMOInstance // CAUTION: This function requires access to the CMPIClassCache, and // therefore can only be called from within a CMPI provider !!! SCMOInstance* CMPISCMOUtilities::getSCMOFromCIMInstance( const CIMInstance& cimInst) { const CIMObjectPath& cimPath = cimInst.getPath(); CString nameSpace = cimPath.getNameSpace().getString().getCString(); CString className = cimPath.getClassName().getString().getCString(); SCMOClass* scmoClass = mbGetSCMOClass( 0, (const char*)nameSpace, (const char*)className); SCMOInstance* scmoInst = new SCMOInstance(*scmoClass, cimInst); return scmoInst; } // Function to convert a CIMObjectPath into an SCMOInstance // CAUTION: This function requires access to the CMPIClassCache, and // therefore can only be called from within a CMPI provider !!! SCMOInstance* CMPISCMOUtilities::getSCMOFromCIMObjectPath( const CIMObjectPath& cimPath) { CString nameSpace = cimPath.getNameSpace().getString().getCString(); CString className = cimPath.getClassName().getString().getCString(); SCMOClass* scmoClass = mbGetSCMOClass( 0, (const char*)nameSpace, (const char*)className); SCMOInstance* scmoRef = new SCMOInstance(*scmoClass, cimPath); return scmoRef; } // Function to convert a SCMO Value into a CMPIData structure CMPIrc CMPISCMOUtilities::scmoValue2CMPIData( const SCMBUnion* scmoValue, CMPIType type, CMPIData *data, Uint32 arraySize) { //Initialize CMPIData object data->type = type; data->value.uint64 = 0; data->state = CMPI_goodValue; //Check for NULL CIMValue if( scmoValue == 0 ) { data->state = CMPI_nullValue; return CMPI_RC_OK; } if (type & CMPI_ARRAY) { // Get the type of the element of the CMPIArray CMPIType aType = type&~CMPI_ARRAY; //Allocate CMPIData array to hold the values CMPIData *arrayRoot = new CMPIData[arraySize+1]; // Advance array pointer to first array element CMPIData *aData = arrayRoot; aData++; // Set the type, state and value of array elements for( Uint32 i=0; itype = aType; arrayRoot->value.sint32 = arraySize; CMPI_Array *arr = new CMPI_Array(arrayRoot); // Set the encapsulated array as data data->value.array = reinterpret_cast(new CMPI_Object(arr)); } else { // Check for encpsulated type, which need special handling if (type&CMPI_ENC) { switch (type) { case CMPI_chars: case CMPI_string: { if (scmoValue->extString.pchar) { data->value.string = reinterpret_cast( new CMPI_Object(scmoValue->extString.pchar)); data->type = CMPI_string; } else { data->state=CMPI_nullValue; } break; } case CMPI_dateTime: { CIMDateTime* cimdt = new CIMDateTime(&scmoValue->dateTimeValue); data->value.dateTime = reinterpret_cast (new CMPI_Object(cimdt)); break; } case CMPI_ref: { SCMOInstance* ref = new SCMOInstance(*(scmoValue->extRefPtr)); data->value.ref = reinterpret_cast (new CMPI_Object(ref)); } break; case CMPI_instance: { SCMOInstance* inst = new SCMOInstance(*(scmoValue->extRefPtr)); data->value.inst = reinterpret_cast (new CMPI_Object(inst, true)); } break; default: { // Not supported for this CMPItype return CMPI_RC_ERR_NOT_SUPPORTED; break; } } } else { // For non-encapsulated type simply copy the first 64bit // of the SCMBUnion to CMPIValue if (scmoValue->simple.hasValue) { data->value.uint64 = scmoValue->simple.val.u64; data->state = CMPI_goodValue; } else { data->value.uint64 = 0; data->state = CMPI_nullValue; } } } return CMPI_RC_OK; } PEGASUS_NAMESPACE_END