version 1.15, 2001/06/11 23:11:26
|
version 1.150, 2014/08/27 23:10:08
|
|
|
//%///////////////////////////////////////////////////////////////////////////// |
//%LICENSE//////////////////////////////////////////////////////////////// |
// | // |
// Copyright (c) 2000 The Open Group, BMC Software, Tivoli Systems, IBM |
// 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 | // Permission is hereby granted, free of charge, to any person obtaining a |
// copy of this software and associated documentation files (the "Software"), | // copy of this software and associated documentation files (the "Software"), |
|
|
// and/or sell copies of the Software, and to permit persons to whom the | // 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: | // Software is furnished to do so, subject to the following conditions: |
// | // |
// THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR |
// The above copyright notice and this permission notice shall be included |
// IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, |
// in all copies or substantial portions of the Software. |
// 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) |
// 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. |
// | // |
// Modified By: |
////////////////////////////////////////////////////////////////////////// |
// | // |
//%///////////////////////////////////////////////////////////////////////////// | //%///////////////////////////////////////////////////////////////////////////// |
|
#include <Pegasus/Common/Config.h> |
#include <cassert> |
#include <Pegasus/Common/Constants.h> |
|
#include <errno.h> |
#include <cctype> | #include <cctype> |
#include <cstdio> | #include <cstdio> |
#include <cstdlib> | #include <cstdlib> |
|
#if defined(PEGASUS_OS_TYPE_UNIX) || defined(PEGASUS_OS_VMS) |
|
# include <errno.h> |
|
#endif |
#include "CIMName.h" | #include "CIMName.h" |
|
#include "CIMNameCast.h" |
#include "XmlReader.h" | #include "XmlReader.h" |
#include "XmlWriter.h" | #include "XmlWriter.h" |
#include "CIMQualifier.h" | #include "CIMQualifier.h" |
#include "CIMQualifierDecl.h" | #include "CIMQualifierDecl.h" |
#include "CIMClass.h" | #include "CIMClass.h" |
#include "CIMInstance.h" | #include "CIMInstance.h" |
|
#include "CIMObject.h" |
|
#include "CIMParamValue.h" |
|
#include "System.h" |
|
#include "XmlConstants.h" |
|
|
|
#include <Pegasus/Common/MessageLoader.h> |
|
#include <Pegasus/Common/StringConversion.h> |
|
#include <Pegasus/Common/AutoPtr.h> |
| |
|
PEGASUS_USING_STD; |
PEGASUS_NAMESPACE_BEGIN | PEGASUS_NAMESPACE_BEGIN |
| |
static const Uint32 MESSAGE_SIZE = 128; | static const Uint32 MESSAGE_SIZE = 128; |
| |
//------------------------------------------------------------------------------ | //------------------------------------------------------------------------------ |
// | // |
// expectXmlDeclaration() |
// getXmlDeclaration() |
|
// |
|
// <?xml version="1.0" encoding="utf-8"?> |
// | // |
//------------------------------------------------------------------------------ | //------------------------------------------------------------------------------ |
| |
void XmlReader::expectXmlDeclaration( |
void XmlReader::getXmlDeclaration( |
XmlParser& parser, | XmlParser& parser, |
XmlEntry& entry) |
const char*& xmlVersion, |
|
const char*& xmlEncoding) |
{ | { |
|
XmlEntry entry; |
|
|
if (!parser.next(entry) || | if (!parser.next(entry) || |
entry.type != XmlEntry::XML_DECLARATION || | entry.type != XmlEntry::XML_DECLARATION || |
strcmp(entry.text, "xml") != 0) | strcmp(entry.text, "xml") != 0) |
{ | { |
throw XmlValidationError(parser.getLine(), |
MessageLoaderParms mlParms( |
|
"Common.XmlReader.EXPECTED_XML_STYLE", |
"Expected <?xml ... ?> style declaration"); | "Expected <?xml ... ?> style declaration"); |
|
throw XmlValidationError(parser.getLine(), mlParms); |
|
} |
|
|
|
if (!entry.getAttributeValue("version", xmlVersion)) |
|
{ |
|
MessageLoaderParms mlParms( |
|
"Common.XmlReader.MISSING_XML_ATTRIBUTE", |
|
"missing xml.version attribute"); |
|
throw XmlValidationError(parser.getLine(), mlParms); |
|
} |
|
|
|
if (!entry.getAttributeValue("encoding", xmlEncoding)) |
|
{ |
|
// ATTN-RK-P3-20020403: Is there a default encoding? |
|
} |
|
} |
|
|
|
//------------------------------------------------------------------------------ |
|
// |
|
// testXmlDeclaration () |
|
// |
|
//------------------------------------------------------------------------------ |
|
|
|
Boolean XmlReader::testXmlDeclaration ( |
|
XmlParser& parser, |
|
XmlEntry& entry) |
|
{ |
|
if (!parser.next (entry) || |
|
entry.type != XmlEntry::XML_DECLARATION || |
|
strcmp (entry.text, "xml") != 0) |
|
{ |
|
parser.putBack (entry); |
|
return false; |
} | } |
|
|
|
return true; |
} | } |
| |
//------------------------------------------------------------------------------ | //------------------------------------------------------------------------------ |
|
|
entry.type != XmlEntry::START_TAG || | entry.type != XmlEntry::START_TAG || |
strcmp(entry.text, tagName) != 0) | strcmp(entry.text, tagName) != 0) |
{ | { |
char message[MESSAGE_SIZE]; |
MessageLoaderParms mlParms( |
sprintf(message, "Expected open of %s element", tagName); |
"Common.XmlReader.EXPECTED_OPEN", |
throw XmlValidationError(parser.getLine(), message); |
"Expected open of $0 element", |
|
tagName); |
|
throw XmlValidationError(parser.getLine(), mlParms); |
} | } |
} | } |
| |
|
|
entry.type != XmlEntry::END_TAG || | entry.type != XmlEntry::END_TAG || |
strcmp(entry.text, tagName) != 0) | strcmp(entry.text, tagName) != 0) |
{ | { |
char message[MESSAGE_SIZE]; |
MessageLoaderParms mlParms( |
sprintf(message, "Expected close of %s element, got %s instead", |
"Common.XmlReader.EXPECTED_CLOSE", |
|
"Expected close of $0 element, got $1 instead", |
tagName,entry.text); | tagName,entry.text); |
throw XmlValidationError(parser.getLine(), message); |
throw XmlValidationError(parser.getLine(), mlParms); |
} | } |
} | } |
| |
|
|
entry.type != XmlEntry::EMPTY_TAG) || | entry.type != XmlEntry::EMPTY_TAG) || |
strcmp(entry.text, tagName) != 0) | strcmp(entry.text, tagName) != 0) |
{ | { |
char message[MESSAGE_SIZE]; |
MessageLoaderParms mlParms( |
sprintf(message, |
"Common.XmlReader.EXPECTED_OPENCLOSE", |
"Expected either open or open/close %s element", tagName); |
"Expected either open or open/close $0 element", |
throw XmlValidationError(parser.getLine(), message); |
tagName); |
|
throw XmlValidationError(parser.getLine(), mlParms); |
} | } |
} | } |
| |
|
|
(entry.type != XmlEntry::CONTENT && | (entry.type != XmlEntry::CONTENT && |
entry.type != XmlEntry::CDATA)) | entry.type != XmlEntry::CDATA)) |
{ | { |
throw XmlValidationError(parser.getLine(), |
MessageLoaderParms mlParms( |
"Expected content of CDATA"); |
"Common.XmlReader.EXPECTED_CDATA", |
|
"Expected content or CDATA"); |
|
throw XmlValidationError(parser.getLine(), mlParms); |
} | } |
| |
return true; | return true; |
|
|
| |
//------------------------------------------------------------------------------ | //------------------------------------------------------------------------------ |
// | // |
// testEndTag>() |
// testEndTag() |
// | // |
//------------------------------------------------------------------------------ | //------------------------------------------------------------------------------ |
| |
|
|
XmlEntry& entry, | XmlEntry& entry, |
const char* tagName) | const char* tagName) |
{ | { |
if (!parser.next(entry) || |
if (!parser.next(entry)) |
(entry.type != XmlEntry::START_TAG && |
{ |
|
return false; |
|
} |
|
if ((entry.type != XmlEntry::START_TAG && |
entry.type != XmlEntry::EMPTY_TAG) || | entry.type != XmlEntry::EMPTY_TAG) || |
strcmp(entry.text, tagName) != 0) | strcmp(entry.text, tagName) != 0) |
{ | { |
|
|
| |
//------------------------------------------------------------------------------ | //------------------------------------------------------------------------------ |
// | // |
|
// testStartTagOrEmptyTag() |
|
// |
|
//------------------------------------------------------------------------------ |
|
|
|
Boolean XmlReader::testStartTagOrEmptyTag( |
|
XmlParser& parser, |
|
XmlEntry& entry) |
|
{ |
|
if (!parser.next(entry) || |
|
(entry.type != XmlEntry::START_TAG && |
|
entry.type != XmlEntry::EMPTY_TAG)) |
|
{ |
|
parser.putBack(entry); |
|
return false; |
|
} |
|
|
|
return true; |
|
} |
|
|
|
//------------------------------------------------------------------------------ |
|
// |
// testContentOrCData() | // testContentOrCData() |
// | // |
//------------------------------------------------------------------------------ | //------------------------------------------------------------------------------ |
|
|
| |
//------------------------------------------------------------------------------ | //------------------------------------------------------------------------------ |
// | // |
// testCimStartTag() |
// getCimStartTag() |
// | // |
// <!ELEMENT CIM (MESSAGE|DECLARATION)> | // <!ELEMENT CIM (MESSAGE|DECLARATION)> |
// <!ATTRLIST CIM | // <!ATTRLIST CIM |
|
|
// | // |
//------------------------------------------------------------------------------ | //------------------------------------------------------------------------------ |
| |
void XmlReader::testCimStartTag(XmlParser& parser) |
void XmlReader::getCimStartTag( |
|
XmlParser& parser, |
|
const char*& cimVersion, |
|
const char*& dtdVersion) |
{ | { |
XmlEntry entry; | XmlEntry entry; |
XmlReader::expectStartTag(parser, entry, "CIM"); | XmlReader::expectStartTag(parser, entry, "CIM"); |
| |
const char* cimVersion; |
|
|
|
if (!entry.getAttributeValue("CIMVERSION", cimVersion)) | if (!entry.getAttributeValue("CIMVERSION", cimVersion)) |
throw XmlValidationError( |
|
parser.getLine(), "missing CIM.CIMVERSION attribute"); |
|
|
|
if (strcmp(cimVersion, "2.0") != 0) |
|
throw XmlValidationError(parser.getLine(), |
|
"CIM.CIMVERSION attribute must be \"2.0\""); |
|
|
|
const char* dtdVersion; |
|
|
|
if (!entry.getAttributeValue("DTDVERSION", dtdVersion)) |
|
throw XmlValidationError( |
|
parser.getLine(), "missing CIM.DTDVERSION attribute"); |
|
|
|
if (strcmp(dtdVersion, "2.0") != 0) |
|
throw XmlValidationError(parser.getLine(), |
|
"CIM.DTDVERSION attribute must be \"2.0\""); |
|
} |
|
|
|
//------------------------------------------------------------------------------ |
|
// |
|
// getIsArrayAttribute() |
|
// |
|
//------------------------------------------------------------------------------ |
|
|
|
Boolean XmlReader::getIsArrayAttribute( |
|
Uint32 lineNumber, |
|
const XmlEntry& entry, |
|
const char* tagName, |
|
Boolean& value) |
|
{ |
|
const char* tmp; |
|
|
|
if (!entry.getAttributeValue("ISARRAY", tmp)) |
|
return false; |
|
|
|
if (strcmp(tmp, "true") == 0) |
|
{ | { |
value = true; |
MessageLoaderParms mlParms( |
return true; |
"Common.XmlReader.MISSING_CIMVERSION_ATTRIBUTE", |
|
"missing CIM.CIMVERSION attribute"); |
|
throw XmlValidationError(parser.getLine(), mlParms); |
} | } |
else if (strcmp(tmp, "false") == 0) |
|
|
if (!entry.getAttributeValue("DTDVERSION", dtdVersion)) |
{ | { |
value = false; |
MessageLoaderParms mlParms( |
return true; |
"Common.XmlReader.MISSING_DTDVERSION_ATTRIBUTE", |
|
"missing CIM.DTDVERSION attribute"); |
|
throw XmlValidationError(parser.getLine(), mlParms); |
} | } |
|
|
char buffer[62]; |
|
sprintf(buffer, "Bad %s.%s attribute value", "ISARRAY", tagName); |
|
throw XmlSemanticError(lineNumber, buffer); |
|
return false; |
|
} | } |
| |
//------------------------------------------------------------------------------ | //------------------------------------------------------------------------------ |
|
|
// | // |
//------------------------------------------------------------------------------ | //------------------------------------------------------------------------------ |
| |
String XmlReader::getCimNameAttribute( |
CIMName XmlReader::getCimNameAttribute( |
Uint32 lineNumber, | Uint32 lineNumber, |
const XmlEntry& entry, | const XmlEntry& entry, |
const char* elementName, | const char* elementName, |
Boolean acceptNull) | Boolean acceptNull) |
{ | { |
String name; |
const char* name; |
| |
if (!entry.getAttributeValue("NAME", name)) | if (!entry.getAttributeValue("NAME", name)) |
{ | { |
char buffer[MESSAGE_SIZE]; | char buffer[MESSAGE_SIZE]; |
sprintf(buffer, "missing %s.NAME attribute", elementName); |
sprintf(buffer, "%s.NAME", elementName); |
throw XmlValidationError(lineNumber, buffer); |
MessageLoaderParms mlParms( |
|
"Common.XmlReader.MISSING_ATTRIBUTE", |
|
"missing $0 attribute", |
|
buffer); |
|
|
|
throw XmlValidationError(lineNumber, mlParms); |
} | } |
| |
if (acceptNull && name.size() == 0) |
if (acceptNull && *name == '\0') |
return name; |
return CIMName(); |
|
|
|
Uint32 size = CIMNameLegalASCII(name); |
|
|
|
if (size) |
|
{ |
|
String tmp(name, size); |
|
return CIMName(CIMNameCast(tmp)); |
|
} |
| |
if (!CIMName::legal(name)) | if (!CIMName::legal(name)) |
{ | { |
char buffer[MESSAGE_SIZE]; | char buffer[MESSAGE_SIZE]; |
sprintf(buffer, "Illegal value for %s.NAME attribute", elementName); |
sprintf(buffer, "%s.NAME", elementName); |
throw XmlSemanticError(lineNumber, buffer); |
|
|
MessageLoaderParms mlParms( |
|
"Common.XmlReader.ILLEGAL_VALUE_FOR_ATTRIBUTE", |
|
"Illegal value for $0 attribute", |
|
buffer); |
|
|
|
throw XmlSemanticError(lineNumber, mlParms); |
} | } |
| |
return name; |
return CIMNameCast(name); |
} | } |
| |
//------------------------------------------------------------------------------ | //------------------------------------------------------------------------------ |
|
|
if (!entry.getAttributeValue("CLASSNAME", name)) | if (!entry.getAttributeValue("CLASSNAME", name)) |
{ | { |
char buffer[MESSAGE_SIZE]; | char buffer[MESSAGE_SIZE]; |
sprintf(buffer, "missing %s.CLASSNAME attribute", elementName); |
sprintf(buffer, "%s.CLASSNAME", elementName); |
throw XmlValidationError(lineNumber, buffer); |
|
|
MessageLoaderParms mlParms( |
|
"Common.XmlReader.MISSING_ATTRIBUTE", |
|
"missing $0 attribute", |
|
buffer); |
|
|
|
throw XmlValidationError(lineNumber, mlParms); |
} | } |
| |
if (!CIMName::legal(name)) | if (!CIMName::legal(name)) |
{ | { |
char buffer[MESSAGE_SIZE]; | char buffer[MESSAGE_SIZE]; |
sprintf(buffer, |
sprintf(buffer, "%s.CLASSNAME", elementName); |
"Illegal value for %s.CLASSNAME attribute", elementName); |
|
throw XmlSemanticError(lineNumber, buffer); |
MessageLoaderParms mlParms( |
|
"Common.XmlReader.ILLEGAL_VALUE_FOR_ATTRIBUTE", |
|
"Illegal value for $0 attribute", |
|
buffer); |
|
throw XmlSemanticError(lineNumber, mlParms); |
} | } |
| |
return name; | return name; |
|
|
// | // |
//------------------------------------------------------------------------------ | //------------------------------------------------------------------------------ |
| |
String XmlReader::getClassOriginAttribute( |
CIMName XmlReader::getClassOriginAttribute( |
Uint32 lineNumber, | Uint32 lineNumber, |
const XmlEntry& entry, | const XmlEntry& entry, |
const char* tagName) | const char* tagName) |
|
|
String name; | String name; |
| |
if (!entry.getAttributeValue("CLASSORIGIN", name)) | if (!entry.getAttributeValue("CLASSORIGIN", name)) |
return String(); |
return CIMName(); |
|
|
|
/* Interoperability hack to make the C++ client of OpenPegasus able |
|
to deal with the wbemservices CIMOM delivered with Sun Solaris. |
|
The issue is that the wbemservices delivers Xml responses with |
|
CLASSORIGIN="" |
|
Originally this had been reported with Bug#537. |
|
*/ |
|
if (name.size()==0) |
|
{ |
|
return CIMName(); |
|
} |
| |
if (!CIMName::legal(name)) | if (!CIMName::legal(name)) |
{ | { |
char buffer[MESSAGE_SIZE]; | char buffer[MESSAGE_SIZE]; |
sprintf(buffer, |
sprintf(buffer, "%s.CLASSORIGIN", tagName); |
"Illegal value for %s.CLASSORIGIN attribute", tagName); |
|
throw XmlSemanticError(lineNumber, buffer); |
MessageLoaderParms mlParms( |
|
"Common.XmlReader.ILLEGAL_VALUE_FOR_ATTRIBUTE", |
|
"Illegal value for $0 attribute", |
|
buffer); |
|
throw XmlSemanticError(lineNumber, mlParms); |
|
} |
|
// The CIMName was already checked with legal() + String() |
|
return CIMNameCast(name); |
} | } |
| |
return name; |
//------------------------------------------------------------------------------ |
|
// |
|
// getEmbeddedObjectAttribute() |
|
// |
|
// <!ENTITY % EmbeddedObject "EmbeddedObject (object | instance) #IMPLIED"> |
|
// |
|
// EmbeddedObjectAttributeType: |
|
// NO_EMBEDDED_OBJECT = 0, |
|
// EMBEDDED_OBJECT_ATTR = 1, |
|
// EMBEDDED_INSTANCE_ATTR = 2 |
|
// |
|
//------------------------------------------------------------------------------ |
|
|
|
XmlReader::EmbeddedObjectAttributeType XmlReader::getEmbeddedObjectAttribute( |
|
Uint32 lineNumber, |
|
const XmlEntry& entry, |
|
const char* tagName) |
|
{ |
|
const char* embeddedObject; |
|
|
|
// Check for both upper case and mixed case "EmbeddedObject" |
|
// because of an error in an earlier pegasus version where we |
|
// used upper case in the generation of the attribute name |
|
// whereas the DMTF spec calls for mixed case. |
|
if (!entry.getAttributeValue("EmbeddedObject", embeddedObject) && |
|
!entry.getAttributeValue("EMBEDDEDOBJECT", embeddedObject)) |
|
return NO_EMBEDDED_OBJECT; |
|
|
|
// The embeddedObject attribute, if present, must have the string |
|
// value "object" or "instance". |
|
if (strcmp(embeddedObject, "object") == 0) |
|
{ |
|
return EMBEDDED_OBJECT_ATTR; |
|
} |
|
|
|
if (strcmp(embeddedObject, "instance") == 0) |
|
{ |
|
return EMBEDDED_INSTANCE_ATTR; |
|
} |
|
|
|
char buffer[MESSAGE_SIZE]; |
|
sprintf(buffer, "%s.EmbeddedObject", tagName); |
|
|
|
MessageLoaderParms mlParms( |
|
"Common.XmlReader.ILLEGAL_VALUE_FOR_ATTRIBUTE", |
|
"Illegal value for $0 attribute", |
|
buffer); |
|
throw XmlSemanticError(lineNumber, mlParms); |
|
|
|
return NO_EMBEDDED_OBJECT; |
} | } |
| |
//------------------------------------------------------------------------------ | //------------------------------------------------------------------------------ |
|
|
// | // |
//------------------------------------------------------------------------------ | //------------------------------------------------------------------------------ |
| |
String XmlReader::getReferenceClassAttribute( |
CIMName XmlReader::getReferenceClassAttribute( |
Uint32 lineNumber, | Uint32 lineNumber, |
const XmlEntry& entry, | const XmlEntry& entry, |
const char* elementName) | const char* elementName) |
|
|
String name; | String name; |
| |
if (!entry.getAttributeValue("REFERENCECLASS", name)) | if (!entry.getAttributeValue("REFERENCECLASS", name)) |
return String(); |
return CIMName(); |
| |
if (!CIMName::legal(name)) | if (!CIMName::legal(name)) |
{ | { |
char buffer[MESSAGE_SIZE]; | char buffer[MESSAGE_SIZE]; |
sprintf(buffer, |
sprintf(buffer, "%s.REFERENCECLASS", elementName); |
"Illegal value for %s.REFERENCECLASS attribute", elementName); |
|
throw XmlSemanticError(lineNumber, buffer); |
|
} |
|
| |
return name; |
MessageLoaderParms mlParms( |
|
"Common.XmlReader.ILLEGAL_VALUE_FOR_ATTRIBUTE", |
|
"Illegal value for $0 attribute", |
|
buffer); |
|
throw XmlSemanticError(lineNumber, mlParms); |
|
} |
|
// The CIMName was already checked with legal() + String() |
|
return CIMNameCast(name); |
} | } |
| |
//------------------------------------------------------------------------------ | //------------------------------------------------------------------------------ |
|
|
// | // |
//------------------------------------------------------------------------------ | //------------------------------------------------------------------------------ |
| |
String XmlReader::getSuperClassAttribute( |
CIMName XmlReader::getSuperClassAttribute( |
Uint32 lineNumber, | Uint32 lineNumber, |
const XmlEntry& entry, | const XmlEntry& entry, |
const char* tagName) | const char* tagName) |
|
|
String superClass; | String superClass; |
| |
if (!entry.getAttributeValue("SUPERCLASS", superClass)) | if (!entry.getAttributeValue("SUPERCLASS", superClass)) |
return String(); |
return CIMName(); |
| |
if (!CIMName::legal(superClass)) | if (!CIMName::legal(superClass)) |
{ | { |
char buffer[MESSAGE_SIZE]; | char buffer[MESSAGE_SIZE]; |
sprintf( |
sprintf(buffer, "%s.SUPERCLASS", tagName); |
buffer, "Illegal value for %s.SUPERCLASS attribute", tagName); |
|
throw XmlSemanticError(lineNumber, buffer); |
|
} |
|
| |
return superClass; |
MessageLoaderParms mlParms( |
|
"Common.XmlReader.ILLEGAL_VALUE_FOR_ATTRIBUTE", |
|
"Illegal value for $0 attribute", |
|
buffer); |
|
throw XmlSemanticError(lineNumber, mlParms); |
|
} |
|
// The CIMName was already checked with legal() + String() |
|
return CIMNameCast(superClass); |
} | } |
| |
//------------------------------------------------------------------------------ | //------------------------------------------------------------------------------ |
// | // |
// getCimTypeAttribute() | // getCimTypeAttribute() |
// | // |
|
// This method can be used to get a TYPE attribute or a PARAMTYPE attribute. |
|
// The only significant difference is that PARAMTYPE may specify a value of |
|
// "reference" type. This method recognizes these attributes by name, and |
|
// does not allow a "TYPE" attribute to be of "reference" type. |
|
// |
// <!ENTITY % CIMType "TYPE (boolean|string|char16|uint8|sint8|uint16 | // <!ENTITY % CIMType "TYPE (boolean|string|char16|uint8|sint8|uint16 |
// |sint16|uint32|sint32|uint64|sint64|datetime|real32|real64)"> | // |sint16|uint32|sint32|uint64|sint64|datetime|real32|real64)"> |
// | // |
|
// <!ENTITY % ParamType "PARAMTYPE (boolean|string|char16|uint8|sint8 |
|
// |uint16|sint16|uint32|sint32|uint64|sint64|datetime|real32|real64 |
|
// |reference)"> |
|
// |
//------------------------------------------------------------------------------ | //------------------------------------------------------------------------------ |
| |
CIMType XmlReader::getCimTypeAttribute( |
Boolean XmlReader::getCimTypeAttribute( |
Uint32 lineNumber, | Uint32 lineNumber, |
const XmlEntry& entry, | const XmlEntry& entry, |
const char* tagName) |
CIMType& cimType, // Output parameter |
|
const char* tagName, |
|
const char* attributeName, |
|
Boolean required) |
{ | { |
const char* typeName; | const char* typeName; |
| |
if (!entry.getAttributeValue("TYPE", typeName)) |
if (!entry.getAttributeValue(attributeName, typeName)) |
|
{ |
|
if (required) |
{ | { |
char message[MESSAGE_SIZE]; | char message[MESSAGE_SIZE]; |
sprintf(message, "missing %s.TYPE attribute", tagName); |
sprintf(message, "%s.%s", tagName, attributeName); |
throw XmlValidationError(lineNumber, message); |
|
|
MessageLoaderParms mlParms( |
|
"Common.XmlReader.MISSING_ATTRIBUTE", |
|
"missing $0 attribute", |
|
message); |
|
throw XmlValidationError(lineNumber, mlParms); |
|
} |
|
else |
|
{ |
|
return false; |
|
} |
} | } |
| |
CIMType type = CIMType::NONE; |
CIMType type = CIMTYPE_BOOLEAN; |
|
Boolean unrecognizedType = false; |
| |
if (strcmp(typeName, "boolean") == 0) | if (strcmp(typeName, "boolean") == 0) |
type = CIMType::BOOLEAN; |
type = CIMTYPE_BOOLEAN; |
else if (strcmp(typeName, "string") == 0) | else if (strcmp(typeName, "string") == 0) |
type = CIMType::STRING; |
type = CIMTYPE_STRING; |
else if (strcmp(typeName, "char16") == 0) | else if (strcmp(typeName, "char16") == 0) |
type = CIMType::CHAR16; |
type = CIMTYPE_CHAR16; |
else if (strcmp(typeName, "uint8") == 0) | else if (strcmp(typeName, "uint8") == 0) |
type = CIMType::UINT8; |
type = CIMTYPE_UINT8; |
else if (strcmp(typeName, "sint8") == 0) | else if (strcmp(typeName, "sint8") == 0) |
type = CIMType::SINT8; |
type = CIMTYPE_SINT8; |
else if (strcmp(typeName, "uint16") == 0) | else if (strcmp(typeName, "uint16") == 0) |
type = CIMType::UINT16; |
type = CIMTYPE_UINT16; |
else if (strcmp(typeName, "sint16") == 0) | else if (strcmp(typeName, "sint16") == 0) |
type = CIMType::SINT16; |
type = CIMTYPE_SINT16; |
else if (strcmp(typeName, "uint32") == 0) | else if (strcmp(typeName, "uint32") == 0) |
type = CIMType::UINT32; |
type = CIMTYPE_UINT32; |
else if (strcmp(typeName, "sint32") == 0) | else if (strcmp(typeName, "sint32") == 0) |
type = CIMType::SINT32; |
type = CIMTYPE_SINT32; |
else if (strcmp(typeName, "uint64") == 0) | else if (strcmp(typeName, "uint64") == 0) |
type = CIMType::UINT64; |
type = CIMTYPE_UINT64; |
else if (strcmp(typeName, "sint64") == 0) | else if (strcmp(typeName, "sint64") == 0) |
type = CIMType::SINT64; |
type = CIMTYPE_SINT64; |
else if (strcmp(typeName, "datetime") == 0) | else if (strcmp(typeName, "datetime") == 0) |
type = CIMType::DATETIME; |
type = CIMTYPE_DATETIME; |
else if (strcmp(typeName, "real32") == 0) | else if (strcmp(typeName, "real32") == 0) |
type = CIMType::REAL32; |
type = CIMTYPE_REAL32; |
else if (strcmp(typeName, "real64") == 0) | else if (strcmp(typeName, "real64") == 0) |
type = CIMType::REAL64; |
type = CIMTYPE_REAL64; |
else if (strcmp(typeName, "reference") == 0) | else if (strcmp(typeName, "reference") == 0) |
type = CIMType::REFERENCE; |
type = CIMTYPE_REFERENCE; |
|
// PEP 194: |
|
// Note that "object" (ie. CIMTYPE_OBJECT) is not a real CIM datatype, just a |
|
// Pegasus internal representation of an embedded object, so it won't be |
|
// found here. |
|
else unrecognizedType = true; |
|
|
|
if (unrecognizedType || |
|
((type == CIMTYPE_REFERENCE) && |
|
(strcmp(attributeName, "PARAMTYPE") != 0))) |
|
{ |
|
char buffer[MESSAGE_SIZE]; |
|
sprintf(buffer, "%s.%s", tagName, attributeName); |
| |
// ATTN: "reference" is not legal according to the DTD; however, it is |
MessageLoaderParms mlParms( |
// used by the XML version of the CIM schema. |
"Common.XmlReader.ILLEGAL_VALUE_FOR_ATTRIBUTE", |
|
"Illegal value for $0 attribute", |
|
buffer); |
| |
if (type == CIMType::NONE) |
throw XmlSemanticError(lineNumber, mlParms); |
{ |
|
char message[MESSAGE_SIZE]; |
|
sprintf(message, "Illegal value for %s.TYPE attribute", tagName); |
|
throw XmlSemanticError(lineNumber, message); |
|
} | } |
| |
return type; |
cimType = type; |
|
return true; |
} | } |
| |
//------------------------------------------------------------------------------ | //------------------------------------------------------------------------------ |
|
|
if (!required) | if (!required) |
return defaultValue; | return defaultValue; |
| |
char buffer[62]; |
char buffer[MESSAGE_SIZE]; |
sprintf(buffer, "missing required %s.%s attribute", |
sprintf(buffer, "%s.%s", attributeName, tagName); |
attributeName, tagName); |
|
| |
throw XmlValidationError(lineNumber, buffer); |
MessageLoaderParms mlParms( |
|
"Common.XmlReader.MISSING_REQUIRED_ATTRIBUTE", |
|
"missing required $0 attribute", |
|
buffer); |
|
throw XmlValidationError(lineNumber, mlParms); |
} | } |
| |
if (strcmp(tmp, "true") == 0) | if (strcmp(tmp, "true") == 0) |
|
|
else if (strcmp(tmp, "false") == 0) | else if (strcmp(tmp, "false") == 0) |
return false; | return false; |
| |
char buffer[62]; |
char buffer[MESSAGE_SIZE]; |
sprintf(buffer, "Bad %s.%s attribute value", attributeName, tagName); |
sprintf(buffer, "%s.%s", attributeName, tagName); |
throw XmlSemanticError(lineNumber, buffer); |
|
return false; |
|
} |
|
|
|
//------------------------------------------------------------------------------ |
|
// |
|
// SringToReal() |
|
// |
|
// [ "+" | "-" ] *decimalDigit "." 1*decimalDigit |
|
// [ ( "e" | "E" ) [ "+" | "-" ] 1*decimalDigit ] |
|
// |
|
//------------------------------------------------------------------------------ |
|
|
|
Boolean XmlReader::stringToReal(const char* stringValue, Real64& x) |
|
{ |
|
const char* p = stringValue; |
|
|
|
if (!*p) |
|
return false; |
|
|
|
// Skip optional sign: |
|
|
|
if (*p == '+' || *p == '-') |
|
p++; |
|
|
|
// Skip optional first set of digits: |
|
|
|
while (isdigit(*p)) |
|
p++; |
|
|
|
// Test required dot: |
|
| |
if (*p++ != '.') |
MessageLoaderParms mlParms( |
return false; |
"Common.XmlReader.INVALID_ATTRIBUTE", |
|
"Invalid $0 attribute value", |
|
buffer); |
| |
// One or more digits required: |
throw XmlSemanticError(lineNumber, mlParms); |
| |
if (!isdigit(*p++)) |
|
return false; | return false; |
|
} |
| |
while (isdigit(*p)) |
// See http://www.ietf.org/rfc/rfc2396.txt section 2 |
p++; |
// |
|
// Also see the "CIM Operations over HTTP" spec, section 3.3.2 and |
// If there is an exponent now: |
// 3.3.3, for the treatment of non US-ASCII chars (UTF-8) |
|
String XmlReader::decodeURICharacters(String uriString) |
if (*p) |
|
{ | { |
// Test exponent: |
Uint32 i; |
|
|
if (*p != 'e' && *p != 'E') |
|
return false; |
|
|
|
p++; |
|
|
|
// Skip optional sign: |
|
|
|
if (*p == '+' || *p == '-') |
|
p++; |
|
| |
// One or more digits required: |
Buffer utf8Chars; |
| |
if (!isdigit(*p++)) |
for (i=0; i<uriString.size(); i++) |
return false; |
{ |
|
if (uriString[i] == '%') |
|
{ |
|
if (i+2 >= uriString.size()) |
|
{ |
|
MessageLoaderParms mlParms( |
|
"Common.XmlReader.INVALID_URI_ENCODING", |
|
"Invalid URI encoding"); |
|
throw ParseError(MessageLoader::getMessage(mlParms)); |
|
} |
| |
while (isdigit(*p)) |
Uint8 digit1 = |
p++; |
StringConversion::hexCharToNumeric(char(uriString[++i])); |
|
Uint8 digit2 = |
|
StringConversion::hexCharToNumeric(char(uriString[++i])); |
|
if ( (digit1 > 15) || (digit2 > 15) ) |
|
{ |
|
MessageLoaderParms mlParms( |
|
"Common.XmlReader.INVALID_URI_ENCODING", |
|
"Invalid URI encoding"); |
|
throw ParseError(MessageLoader::getMessage(mlParms)); |
} | } |
| |
if (*p) |
Uint16 decodedChar = Uint16(digit1<<4) + Uint16(digit2); |
return false; |
utf8Chars.append((char)decodedChar); |
|
} |
|
else |
|
{ |
|
utf8Chars.append((char)uriString[i]); |
|
} |
|
} |
| |
char* end; |
// If there was a string to decode... |
x = strtod(stringValue, &end); |
if (uriString.size() > 0) |
return true; |
{ |
|
// Convert UTF-8 to UTF-16 and return the String |
|
return String(utf8Chars.getData(), utf8Chars.size()); |
|
} |
|
else |
|
{ |
|
return String(); |
|
} |
} | } |
| |
//------------------------------------------------------------------------------ | //------------------------------------------------------------------------------ |
// | // |
// stringToSignedInteger |
// stringToValue() |
|
// |
|
// Return: CIMValue. If the string input is zero length creates a CIMValue |
|
// with value defined by the type. Else the value is inserted. |
// | // |
// [ "+" | "-" ] ( positiveDecimalDigit *decimalDigit | "0" ) |
// Note that this does not set the CIMValue Null if the string is empty. |
// | // |
// ATTN-B: handle conversion from hexadecimal. |
|
//------------------------------------------------------------------------------ | //------------------------------------------------------------------------------ |
| |
Boolean XmlReader::stringToSignedInteger( |
CIMValue XmlReader::stringToValue( |
const char* stringValue, |
Uint32 lineNumber, |
Sint64& x) |
const char* valueString, |
|
CIMType type) |
{ | { |
x = 0; |
return stringToValue(lineNumber, valueString, strlen(valueString), type); |
const char* p = stringValue; |
} |
|
|
if (!*p) |
|
return false; |
|
|
|
// Skip optional sign: |
|
|
|
Boolean negative = *p == '-'; |
|
|
|
if (negative || *p == '+') |
|
p++; |
|
|
|
// If the next thing is a zero, then it must be the last: |
|
|
|
if (*p == '0') |
|
return p[1] == '\0'; |
|
|
|
// Expect a positive decimal digit: |
|
|
|
const char* first = p; |
|
|
|
if (!isdigit(*p) || *p == '0') |
|
return false; |
|
|
|
p++; |
|
|
|
// Expect zero or more digits: |
|
|
|
while (isdigit(*p)) |
|
p++; |
|
| |
if (*p) |
CIMValue XmlReader::stringToValue( |
return false; |
Uint32 lineNumber, |
|
const char* valueString, |
|
Uint32 valueStringLen, |
|
CIMType type) |
|
{ |
|
// ATTN-B: accepting only UTF-8 for now! (affects string and char16): |
| |
const char* last = p; |
// Char string must have been null terminated. |
|
PEGASUS_ASSERT (!valueString[valueStringLen]); |
| |
while (first != last) |
// Create value per type |
x = 10 * x + (*first++ - '0'); |
switch (type) |
|
{ |
|
case CIMTYPE_BOOLEAN: |
|
{ |
|
if (System::strcasecmp(valueString, "TRUE") == 0) |
|
return CIMValue(true); |
|
else if (System::strcasecmp(valueString, "FALSE") == 0) |
|
return CIMValue(false); |
|
else |
|
{ |
|
MessageLoaderParms mlParms( |
|
"Common.XmlReader.INVALID_BOOLEAN_VALUE", |
|
"Invalid boolean value"); |
|
throw XmlSemanticError(lineNumber, mlParms); |
|
} |
|
} |
| |
if (negative) |
case CIMTYPE_STRING: |
x = -x; |
{ |
|
return CIMValue(String(valueString, valueStringLen)); |
|
} |
| |
return true; |
case CIMTYPE_CHAR16: |
|
{ |
|
// Converts UTF-8 to UTF-16 |
|
String tmp(valueString, valueStringLen); |
|
if (tmp.size() != 1) |
|
{ |
|
MessageLoaderParms mlParms( |
|
"Common.XmlReader.INVALID_CHAR16_VALUE", |
|
"Invalid char16 value"); |
|
throw XmlSemanticError(lineNumber, mlParms); |
} | } |
| |
//------------------------------------------------------------------------------ |
return CIMValue(tmp[0]); |
// |
} |
// stringToUnsignedInteger |
|
// |
|
// [ "+" | "-" ] ( positiveDecimalDigit *decimalDigit | "0" ) |
|
// |
|
// ATTN-B: handle conversion from hexadecimal. |
|
//------------------------------------------------------------------------------ |
|
| |
Boolean XmlReader::stringToUnsignedInteger( |
case CIMTYPE_UINT8: |
const char* stringValue, |
case CIMTYPE_UINT16: |
Uint64& x) |
case CIMTYPE_UINT32: |
|
case CIMTYPE_UINT64: |
{ | { |
x = 0; |
Uint64 x; |
const char* p = stringValue; |
|
| |
if (!*p) |
if (!StringConversion::stringToUnsignedInteger(valueString, x)) |
return false; |
|
|
|
// Skip optional sign: |
|
|
|
if (*p == '-') |
|
return false; |
|
|
|
if (*p == '+') |
|
p++; |
|
|
|
// If the next thing is a zero, then it must be the last: |
|
|
|
if (*p == '0') |
|
return p[1] == '\0'; |
|
|
|
// Expect a positive decimal digit: |
|
|
|
const char* first = p; |
|
|
|
if (!isdigit(*p) || *p == '0') |
|
return false; |
|
|
|
p++; |
|
|
|
// Expect zero or more digits: |
|
|
|
while (isdigit(*p)) |
|
p++; |
|
|
|
if (*p) |
|
return false; |
|
|
|
const char* last = p; |
|
|
|
while (first != last) |
|
x = 10 * x + (*first++ - '0'); |
|
|
|
return true; |
|
} |
|
|
|
//------------------------------------------------------------------------------ |
|
// |
|
// stringToValue() |
|
// |
|
// ATTN-C: note that integers are truncated without warning. What should be |
|
// done in this case? In C they are truncated without warning by design. |
|
// |
|
//------------------------------------------------------------------------------ |
|
|
|
CIMValue XmlReader::stringToValue( |
|
Uint32 lineNumber, |
|
const char* valueString, |
|
CIMType type) |
|
{ | { |
// ATTN-B: accepting only UTF-8 for now! (affects string and char16): |
MessageLoaderParms mlParms( |
|
"Common.XmlReader.INVALID_UI_VALUE", |
//SNIA |
"Invalid unsigned integer value"); |
if (strlen(valueString)==0) { |
throw XmlSemanticError(lineNumber, mlParms); |
switch (type) { |
|
case CIMType::BOOLEAN: return CIMValue(false); |
|
case CIMType::STRING: return CIMValue(valueString); |
|
case CIMType::CHAR16: return CIMValue(Char16('\0')); |
|
case CIMType::UINT8: return CIMValue(Uint8(0)); |
|
case CIMType::UINT16: return CIMValue(Uint16(0)); |
|
case CIMType::UINT32: return CIMValue(Uint32(0)); |
|
case CIMType::UINT64: return CIMValue(Uint64(0)); |
|
case CIMType::SINT8: return CIMValue(Sint8(0)); |
|
case CIMType::SINT16: return CIMValue(Sint16(0)); |
|
case CIMType::SINT32: return CIMValue(Sint32(0)); |
|
case CIMType::SINT64: return CIMValue(Sint64(0)); |
|
case CIMType::REAL32: return CIMValue(Real32(0)); |
|
case CIMType::REAL64: return CIMValue(Real64(0)); |
|
} |
|
} | } |
// end of SNIA |
|
| |
switch (type) | switch (type) |
{ | { |
case CIMType::BOOLEAN: |
case CIMTYPE_UINT8: |
{ | { |
if (CompareNoCase(valueString, "TRUE") == 0) |
if (!StringConversion::checkUintBounds(x, type)) |
return CIMValue(true); |
|
else if (CompareNoCase(valueString, "FALSE") == 0) |
|
return CIMValue(false); |
|
else |
|
throw XmlSemanticError( |
|
lineNumber, "Bad boolean value"); |
|
} |
|
|
|
case CIMType::STRING: |
|
{ | { |
return CIMValue(valueString); |
MessageLoaderParms mlParms( |
|
"Common.XmlReader.U8_VALUE_OUT_OF_RANGE", |
|
"Uint8 value out of range"); |
|
throw XmlSemanticError(lineNumber, mlParms); |
} | } |
|
return CIMValue(Uint8(x)); |
case CIMType::CHAR16: |
|
{ |
|
if (strlen(valueString) != 1) |
|
throw XmlSemanticError(lineNumber, "Bad char16 value"); |
|
|
|
return CIMValue(Char16(valueString[0])); |
|
} | } |
|
case CIMTYPE_UINT16: |
case CIMType::UINT8: |
|
case CIMType::UINT16: |
|
case CIMType::UINT32: |
|
case CIMType::UINT64: |
|
{ | { |
Uint64 x; |
if (!StringConversion::checkUintBounds(x, type)) |
|
|
if (!stringToUnsignedInteger(valueString, x)) |
|
{ | { |
throw XmlSemanticError( |
MessageLoaderParms mlParms( |
lineNumber, "Bad unsigned integer value"); |
"Common.XmlReader.U16_VALUE_OUT_OF_RANGE", |
|
"Uint16 value out of range"); |
|
throw XmlSemanticError(lineNumber, mlParms); |
} | } |
|
return CIMValue(Uint16(x)); |
switch (type) |
} |
|
case CIMTYPE_UINT32: |
{ | { |
case CIMType::UINT8: return CIMValue(Uint8(x)); |
if (!StringConversion::checkUintBounds(x, type)) |
case CIMType::UINT16: return CIMValue(Uint16(x)); |
{ |
case CIMType::UINT32: return CIMValue(Uint32(x)); |
MessageLoaderParms mlParms( |
case CIMType::UINT64: return CIMValue(Uint64(x)); |
"Common.XmlReader.U32_VALUE_OUT_OF_RANGE", |
|
"Uint32 value out of range"); |
|
throw XmlSemanticError(lineNumber, mlParms); |
|
} |
|
return CIMValue(Uint32(x)); |
|
} |
|
case CIMTYPE_UINT64: return CIMValue(Uint64(x)); |
default: break; | default: break; |
} | } |
} | } |
| |
case CIMType::SINT8: |
case CIMTYPE_SINT8: |
case CIMType::SINT16: |
case CIMTYPE_SINT16: |
case CIMType::SINT32: |
case CIMTYPE_SINT32: |
case CIMType::SINT64: |
case CIMTYPE_SINT64: |
{ | { |
Sint64 x; | Sint64 x; |
| |
if (!stringToSignedInteger(valueString, x)) |
if (!StringConversion::stringToSignedInteger(valueString, x)) |
{ | { |
throw XmlSemanticError( |
MessageLoaderParms mlParms( |
lineNumber, "Bad signed integer value"); |
"Common.XmlReader.INVALID_SI_VALUE", |
|
"Invalid signed integer value"); |
|
throw XmlSemanticError(lineNumber, mlParms); |
} | } |
| |
switch (type) | switch (type) |
{ | { |
case CIMType::SINT8: return CIMValue(Sint8(x)); |
case CIMTYPE_SINT8: |
case CIMType::SINT16: return CIMValue(Sint16(x)); |
{ |
case CIMType::SINT32: return CIMValue(Sint32(x)); |
if (!StringConversion::checkSintBounds(x, type)) |
case CIMType::SINT64: return CIMValue(Sint64(x)); |
{ |
|
MessageLoaderParms mlParms( |
|
"Common.XmlReader.S8_VALUE_OUT_OF_RANGE", |
|
"Sint8 value out of range"); |
|
throw XmlSemanticError(lineNumber, mlParms); |
|
} |
|
return CIMValue(Sint8(x)); |
|
} |
|
case CIMTYPE_SINT16: |
|
{ |
|
if (!StringConversion::checkSintBounds(x, type)) |
|
{ |
|
MessageLoaderParms mlParms( |
|
"Common.XmlReader.S16_VALUE_OUT_OF_RANGE", |
|
"Sint16 value out of range"); |
|
throw XmlSemanticError(lineNumber, mlParms); |
|
} |
|
return CIMValue(Sint16(x)); |
|
} |
|
case CIMTYPE_SINT32: |
|
{ |
|
if (!StringConversion::checkSintBounds(x, type)) |
|
{ |
|
MessageLoaderParms mlParms( |
|
"Common.XmlReader.S32_VALUE_OUT_OF_RANGE", |
|
"Sint32 value out of range"); |
|
throw XmlSemanticError(lineNumber, mlParms); |
|
} |
|
return CIMValue(Sint32(x)); |
|
} |
|
case CIMTYPE_SINT64: return CIMValue(Sint64(x)); |
default: break; | default: break; |
} | } |
} | } |
| |
case CIMType::DATETIME: |
case CIMTYPE_DATETIME: |
{ | { |
CIMDateTime tmp; | CIMDateTime tmp; |
| |
try | try |
{ | { |
|
if (valueStringLen != 0) |
|
{ |
tmp.set(valueString); | tmp.set(valueString); |
} | } |
catch (BadDateTimeFormat&) |
} |
|
catch (InvalidDateTimeFormatException&) |
{ | { |
throw XmlSemanticError(lineNumber, "Bad datetime value"); |
MessageLoaderParms mlParms( |
|
"Common.XmlReader.INVALID_DATETIME_VALUE", |
|
"Invalid datetime value"); |
|
throw XmlSemanticError(lineNumber, mlParms); |
} | } |
| |
return CIMValue(tmp); | return CIMValue(tmp); |
} | } |
| |
case CIMType::REAL32: |
case CIMTYPE_REAL32: |
{ | { |
Real64 x; | Real64 x; |
| |
if (!stringToReal(valueString, x)) |
if (!StringConversion::stringToReal64(valueString, x)) |
throw XmlSemanticError(lineNumber, "Bad real value"); |
{ |
|
MessageLoaderParms mlParms( |
|
"Common.XmlReader.INVALID_RN_VALUE", |
|
"Invalid real number value"); |
|
throw XmlSemanticError(lineNumber, mlParms); |
|
} |
return CIMValue(Real32(x)); | return CIMValue(Real32(x)); |
} | } |
| |
case CIMType::REAL64: |
case CIMTYPE_REAL64: |
{ | { |
Real64 x; | Real64 x; |
| |
if (!stringToReal(valueString, x)) |
if (!StringConversion::stringToReal64(valueString, x)) |
throw XmlSemanticError(lineNumber, "Bad real value"); |
{ |
|
MessageLoaderParms mlParms( |
|
"Common.XmlReader.INVALID_RN_VALUE", |
|
"Invalid real number value"); |
|
throw XmlSemanticError(lineNumber, mlParms); |
|
} |
|
return CIMValue(x); |
|
} |
|
|
|
// PEP 194: |
|
// Note that "object" (ie. CIMTYPE_OBJECT) is not a real CIM datatype, but |
|
// just a Pegasus internal representation of an embedded object. However, |
|
// this case is used when decoding string representations of embedded objects. |
|
case CIMTYPE_OBJECT: |
|
case CIMTYPE_INSTANCE: |
|
{ |
|
CIMObject x; |
|
|
|
if (*valueString == '\0') |
|
{ |
|
return CIMValue(type, false, 0); |
|
} |
|
else |
|
{ |
|
// Convert the non-NULL string to a CIMObject (containing |
|
// either a CIMInstance or a CIMClass). |
| |
|
// First we need to create a new "temporary" XmlParser that is |
|
// just the value of the Embedded Object in String |
|
// representation. |
|
AutoArrayPtr<char> tmp_buffer( |
|
new char[valueStringLen + 1]); |
|
memcpy(tmp_buffer.get(), valueString, valueStringLen + 1); |
|
XmlParser tmp_parser(tmp_buffer.get()); |
|
|
|
// The next bit of logic constructs a CIMObject from the |
|
// Embedded Object String. It is similar to the method |
|
// XmlReader::getValueObjectElement(). |
|
CIMInstance cimInstance; |
|
CIMClass cimClass; |
|
|
|
if (XmlReader::getInstanceElement(tmp_parser, cimInstance)) |
|
{ |
|
if (type == CIMTYPE_INSTANCE) |
|
return CIMValue(cimInstance); |
|
x = CIMObject(cimInstance); |
|
} |
|
else if (XmlReader::getClassElement(tmp_parser, cimClass)) |
|
{ |
|
x = CIMObject(cimClass); |
|
} |
|
else |
|
{ |
|
if (type == CIMTYPE_OBJECT) |
|
{ |
|
// change "element" to "embedded object" |
|
MessageLoaderParms mlParms( |
|
"Common.XmlReader." |
|
"EXPECTED_INSTANCE_OR_CLASS_ELEMENT", |
|
"Expected INSTANCE or CLASS element"); |
|
throw XmlValidationError(lineNumber, mlParms); |
|
} |
|
else |
|
{ |
|
// change "element" to "embedded object" |
|
MessageLoaderParms mlParms( |
|
"Common.XmlReader.EXPECTED_INSTANCE_ELEMENT", |
|
"Expected INSTANCE element"); |
|
throw XmlValidationError(lineNumber, mlParms); |
|
} |
|
} |
|
// Ok, now we can delete the storage for the temporary |
|
// XmlParser. |
|
tmp_buffer.reset(); |
|
} |
return CIMValue(x); | return CIMValue(x); |
} | } |
| |
|
|
break; | break; |
} | } |
| |
throw XmlSemanticError(lineNumber, "malformed XML"); |
MessageLoaderParms mlParms( |
|
"Common.XmlReader.MALFORMED_XML", |
|
"malformed XML"); |
|
throw XmlSemanticError(lineNumber, mlParms); |
|
|
return false; | return false; |
} | } |
| |
//------------------------------------------------------------------------------ | //------------------------------------------------------------------------------ |
// | // |
|
// skipElement() |
|
// |
|
//------------------------------------------------------------------------------ |
|
void XmlReader::skipElement( |
|
XmlParser& parser, |
|
XmlEntry& entry) |
|
{ |
|
const char * tag_name = entry.text; |
|
|
|
if (entry.type == XmlEntry::EMPTY_TAG) |
|
{ |
|
return; |
|
} |
|
|
|
while (testStartTagOrEmptyTag(parser, entry)) |
|
{ |
|
skipElement(parser, entry); |
|
} |
|
|
|
if (testContentOrCData(parser, entry)) |
|
{ |
|
; // skip |
|
} |
|
|
|
expectEndTag(parser, tag_name); |
|
return; |
|
} |
|
|
|
//------------------------------------------------------------------------------ |
|
// |
// getValueElement() | // getValueElement() |
// | // |
// <!ELEMENT VALUE (#PCDATA)> | // <!ELEMENT VALUE (#PCDATA)> |
// | // |
|
// Return: false if no value element. |
|
// |
//------------------------------------------------------------------------------ | //------------------------------------------------------------------------------ |
| |
Boolean XmlReader::getValueElement( | Boolean XmlReader::getValueElement( |
|
|
CIMType type, | CIMType type, |
CIMValue& value) | CIMValue& value) |
{ | { |
// Get VALUE start tag: |
// Get VALUE start tag: Return false if no VALUE start Tag |
| |
XmlEntry entry; | XmlEntry entry; |
if (!testStartTagOrEmptyTag(parser, entry, "VALUE")) | if (!testStartTagOrEmptyTag(parser, entry, "VALUE")) |
|
{ |
return false; | return false; |
|
} |
| |
Boolean empty = entry.type == XmlEntry::EMPTY_TAG; | Boolean empty = entry.type == XmlEntry::EMPTY_TAG; |
| |
// Get VALUE content: |
|
|
|
const char* valueString = ""; | const char* valueString = ""; |
// cout << "DEBUG XMLReader:getValueElement " << __LINE__ ; |
Uint32 valueStringLen = 0; |
|
|
if (!empty) | if (!empty) |
{ | { |
if (testContentOrCData(parser, entry)) | if (testContentOrCData(parser, entry)) |
|
{ |
valueString = entry.text; | valueString = entry.text; |
//cout << "DEBUG XMLReader:getValueElement " << __LINE__ |
valueStringLen = entry.textLen; |
// << " valueString " << valueString ; |
} |
| |
expectEndTag(parser, "VALUE"); | expectEndTag(parser, "VALUE"); |
} | } |
|
value = stringToValue(parser.getLine(),valueString,valueStringLen,type); |
| |
value = stringToValue(parser.getLine(), valueString,type); |
|
//cout << "DEBUG XMLReader:getValueElement " << __LINE__ |
|
// << " value " << value; |
|
return true; | return true; |
} | } |
| |
|
//------------------------------------------------------------------------------ |
//---------------------------------------------------------------------------- |
|
// |
|
// getPropertyValue |
|
// Use: Decode property value from getPropertyResponse |
|
// Expect (ERROR|IRETURNVALUE).!ELEMENT VALUE (#PCDATA)> |
|
// |
|
// PropertyValue: |
|
// <!ELEMENT VALUE> |
|
// | // |
// <!ELEMENT VALUE.ARRAY (VALUE*)> |
// getStringValueElement() |
// | // |
// <!ELEMENT VALUE.REFERENCE (CLASSPATH|LOCALCLASSPATH|CLASSNAME| |
// <!ELEMENT VALUE (#PCDATA)> |
// INSTANCEPATH|LOCALINSTANCEPATH|INSTANCENAME)> |
|
// | // |
//---------------------------------------------------------------------------- |
//------------------------------------------------------------------------------ |
Boolean XmlReader::getPropertyValue( |
|
|
Boolean XmlReader::getStringValueElement( |
XmlParser& parser, | XmlParser& parser, |
CIMValue& cimValue) |
String& str, |
|
Boolean required) |
{ | { |
//Test for Element value type |
XmlEntry entry; |
CIMType type = CIMType::STRING; |
|
| |
if (XmlReader::getValueElement(parser, type, cimValue)) |
if (!testStartTagOrEmptyTag(parser, entry, "VALUE")) |
{ | { |
//cout << "DEBUG xmlReader::getPropertyValue " << __LINE__ |
if (required) |
// << " CimValue = " << cimValue.toString << endl; |
{ |
return true; |
MessageLoaderParms mlParms( |
|
"Common.XmlReader.EXPECTED_VALUE_ELEMENT", |
|
"Expected VALUE element"); |
|
throw XmlValidationError(parser.getLine(), mlParms); |
|
} |
|
return false; |
} | } |
| |
//Test for Element.array value |
Boolean empty = entry.type == XmlEntry::EMPTY_TAG; |
if(XmlReader::getValueArrayElement(parser, type, cimValue)) |
|
return true; |
|
| |
// Test for Value.reference type |
const char* valueString = ""; |
// ATTN:This returns a different type (CIMReference) |
Uint32 valueStringLen = 0; |
// ATTN: Possibly change to simply return result after |
|
// we figure out the type differences. |
|
| |
CIMReference reference; |
if (!empty) |
if(XmlReader::getValueReferenceElement(parser, reference)) |
{ |
return true; |
if (testContentOrCData(parser, entry)) |
|
{ |
|
valueString = entry.text; |
|
valueStringLen = entry.textLen; |
|
} |
| |
return false; |
expectEndTag(parser, "VALUE"); |
|
} |
|
|
|
str = String(valueString, valueStringLen); |
|
return true; |
} | } |
| |
|
// EXP_PULL_BEGIN |
//------------------------------------------------------------------------------ | //------------------------------------------------------------------------------ |
// | // |
// stringArrayToValue() |
// getUint32ArgValueElement() |
|
// |
|
// <!ELEMENT VALUE (#PCDATA)> |
// | // |
//------------------------------------------------------------------------------ | //------------------------------------------------------------------------------ |
| |
template<class T> |
Boolean XmlReader::getUint32ArgValueElement( |
CIMValue StringArrayToValueAux( |
XmlParser& parser, |
Uint32 lineNumber, |
Uint32Arg& val, |
const Array<const char*>& stringArray, |
Boolean required) |
CIMType type, |
|
T*) |
|
{ | { |
Array<T> array; |
XmlEntry entry; |
| |
for (Uint32 i = 0, n = stringArray.size(); i < n; i++) |
if (!testStartTagOrEmptyTag(parser, entry, "VALUE")) |
{ | { |
CIMValue value = XmlReader::stringToValue( |
if (required) |
lineNumber, stringArray[i], type); |
{ |
|
MessageLoaderParms mlParms( |
T x; |
"Common.XmlReader.EXPECTED_VALUE_ELEMENT", |
value.get(x); |
"Expected VALUE element"); |
array.append(x); |
throw XmlValidationError(parser.getLine(), mlParms); |
} | } |
|
return false; |
return CIMValue(array); |
|
} | } |
| |
CIMValue XmlReader::stringArrayToValue( |
Boolean empty = entry.type == XmlEntry::EMPTY_TAG; |
Uint32 lineNumber, |
|
const Array<const char*>& array, |
|
CIMType type) |
|
{ |
|
switch (type) |
|
{ |
|
case CIMType::BOOLEAN: |
|
return StringArrayToValueAux(lineNumber, array, type, (Boolean*)0); |
|
|
|
case CIMType::STRING: |
|
return StringArrayToValueAux(lineNumber, array, type, (String*)0); |
|
|
|
case CIMType::CHAR16: |
|
return StringArrayToValueAux(lineNumber, array, type, (Char16*)0); |
|
|
|
case CIMType::UINT8: |
|
return StringArrayToValueAux(lineNumber, array, type, (Uint8*)0); |
|
|
|
case CIMType::UINT16: |
|
return StringArrayToValueAux(lineNumber, array, type, (Uint16*)0); |
|
|
|
case CIMType::UINT32: |
|
return StringArrayToValueAux(lineNumber, array, type, (Uint32*)0); |
|
|
|
case CIMType::UINT64: |
|
return StringArrayToValueAux(lineNumber, array, type, (Uint64*)0); |
|
|
|
case CIMType::SINT8: |
|
return StringArrayToValueAux(lineNumber, array, type, (Sint8*)0); |
|
|
|
case CIMType::SINT16: |
|
return StringArrayToValueAux(lineNumber, array, type, (Sint16*)0); |
|
|
|
case CIMType::SINT32: |
|
return StringArrayToValueAux(lineNumber, array, type, (Sint32*)0); |
|
| |
case CIMType::SINT64: |
const char* valueString = ""; |
return StringArrayToValueAux(lineNumber, array, type, (Sint64*)0); |
|
| |
case CIMType::DATETIME: |
if (!empty) |
return StringArrayToValueAux(lineNumber, array, type, (CIMDateTime*)0); |
{ |
|
if (testContentOrCData(parser, entry)) |
|
valueString = entry.text; |
| |
case CIMType::REAL32: |
expectEndTag(parser, "VALUE"); |
return StringArrayToValueAux(lineNumber, array, type, (Real32*)0); |
} |
|
else |
|
{ |
|
// create the arg object with the NULL value in it. |
|
val = Uint32Arg(); |
|
return true; |
|
} |
| |
case CIMType::REAL64: |
//convert to Uint32. Note error if overflow. |
return StringArrayToValueAux(lineNumber, array, type, (Real64*)0); |
|
| |
default: |
Uint64 x; |
break; |
if (!StringConversion::stringToUnsignedInteger(valueString, x)) |
|
{ |
|
MessageLoaderParms mlParms( |
|
"Common.XmlReader.INVALID_UI_VALUE", |
|
"Invalid unsigned integer value"); |
|
throw XmlSemanticError(parser.getLine(), mlParms); |
} | } |
| |
// Unreachable: |
if (!StringConversion::checkUintBounds(x, CIMTYPE_UINT32)) |
return CIMValue(); |
{ |
|
MessageLoaderParms mlParms( |
|
"Common.XmlReader.U32_VALUE_OUT_OF_RANGE", |
|
"Uint32 value out of range"); |
|
throw XmlSemanticError(parser.getLine(), mlParms); |
} | } |
|
// create the arg object with the value in it. |
|
val = Uint32Arg(x); |
| |
|
return true; |
|
} |
//------------------------------------------------------------------------------ | //------------------------------------------------------------------------------ |
// | // |
// getValueArrayElement() |
// getUint64ValueElement() |
// | // |
// <!ELEMENT VALUE.ARRAY (VALUE*)> |
// <!ELEMENT VALUE (#PCDATA)> |
// | // |
//------------------------------------------------------------------------------ | //------------------------------------------------------------------------------ |
| |
Boolean XmlReader::getValueArrayElement( |
Boolean XmlReader::getUint64ValueElement( |
XmlParser& parser, | XmlParser& parser, |
CIMType type, |
Uint64Arg& val, |
CIMValue& value) |
Boolean required) |
{ | { |
value.clear(); |
|
|
|
// Get VALUE.ARRAY open tag: |
|
|
|
XmlEntry entry; | XmlEntry entry; |
| |
if (!testStartTagOrEmptyTag(parser, entry, "VALUE.ARRAY")) |
if (!testStartTagOrEmptyTag(parser, entry, "VALUE")) |
return false; |
{ |
|
if (required) |
if (entry.type == XmlEntry::EMPTY_TAG) |
{ |
return true; |
MessageLoaderParms mlParms( |
|
"Common.XmlReader.EXPECTED_VALUE_ELEMENT", |
// For each VALUE element: |
"Expected VALUE element"); |
|
throw XmlValidationError(parser.getLine(), mlParms); |
|
} |
|
return false; |
|
} |
|
|
|
Boolean empty = entry.type == XmlEntry::EMPTY_TAG; |
|
|
|
const char* valueString = ""; |
|
|
|
if (!empty) |
|
{ |
|
if (testContentOrCData(parser, entry)) |
|
valueString = entry.text; |
|
|
|
expectEndTag(parser, "VALUE"); |
|
} |
|
else |
|
{ |
|
// create the arg object with the NULL value in it. |
|
val = Uint64Arg(); |
|
return true; |
|
} |
|
|
|
Uint64 x; |
|
|
|
if (!StringConversion::stringToUnsignedInteger(valueString, x)) |
|
{ |
|
MessageLoaderParms mlParms( |
|
"Common.XmlReader.INVALID_UI_VALUE", |
|
"The unsigned integer value is not valid."); |
|
throw XmlSemanticError(parser.getLine(), mlParms); |
|
} |
|
|
|
// create the arg object with the value in it. |
|
val = Uint64Arg(x); |
|
|
|
return true; |
|
} |
|
|
|
|
|
//------------------------------------------------------------------------------ |
|
// |
|
// getUint32ValueElement() |
|
// |
|
// <!ELEMENT VALUE (#PCDATA)> |
|
// |
|
//------------------------------------------------------------------------------ |
|
|
|
Boolean XmlReader::getUint32ValueElement( |
|
XmlParser& parser, |
|
Uint32& val, |
|
Boolean required) |
|
{ |
|
XmlEntry entry; |
|
|
|
if (!testStartTagOrEmptyTag(parser, entry, "VALUE")) |
|
{ |
|
if (required) |
|
{ |
|
MessageLoaderParms mlParms( |
|
"Common.XmlReader.EXPECTED_VALUE_ELEMENT", |
|
"Expected VALUE element"); |
|
throw XmlValidationError(parser.getLine(), mlParms); |
|
} |
|
return false; |
|
} |
|
|
|
Boolean empty = entry.type == XmlEntry::EMPTY_TAG; |
|
|
|
const char* valueString = ""; |
|
|
|
if (!empty) |
|
{ |
|
if (testContentOrCData(parser, entry)) |
|
valueString = entry.text; |
|
|
|
expectEndTag(parser, "VALUE"); |
|
} |
|
else |
|
{ |
|
// leave the existing value |
|
return true; |
|
} |
|
|
|
//convert to Uint32. Note error if overflow. |
|
|
|
Uint64 x; |
|
if (!StringConversion::stringToUnsignedInteger(valueString, x)) |
|
{ |
|
MessageLoaderParms mlParms( |
|
"Common.XmlReader.INVALID_UI_VALUE", |
|
"Invalid unsigned integer value"); |
|
throw XmlSemanticError(parser.getLine(), mlParms); |
|
} |
|
|
|
if (!StringConversion::checkUintBounds(x, CIMTYPE_UINT32)) |
|
{ |
|
MessageLoaderParms mlParms( |
|
"Common.XmlReader.U32_VALUE_OUT_OF_RANGE", |
|
"Uint32 value out of range"); |
|
throw XmlSemanticError(parser.getLine(), mlParms); |
|
} |
|
// create the arg object with the value in it. |
|
val = x; |
|
|
|
return true; |
|
} |
|
//EXP_PULL_END |
|
|
|
//---------------------------------------------------------------------------- |
|
// |
|
// getPropertyValue |
|
// Use: Decode property value from SetProperty request and |
|
// GetProperty response. |
|
// |
|
// PropertyValue is one of: |
|
// |
|
// |
|
// <!ELEMENT VALUE.ARRAY (VALUE*)> |
|
// |
|
// <!ELEMENT VALUE.REFERENCE (CLASSPATH|LOCALCLASSPATH|CLASSNAME| |
|
// <!ELEMENT VALUE.ARRAY (VALUE*)> |
|
// |
|
// <!ELEMENT VALUE.REFERENCE (CLASSPATH|LOCALCLASSPATH|CLASSNAME| |
|
// INSTANCEPATH|LOCALINSTANCEPATH|INSTANCENAME)> |
|
// |
|
// <!ELEMENT VALUE.REFARRAY (VALUE.REFERENCE*)> |
|
// |
|
//---------------------------------------------------------------------------- |
|
Boolean XmlReader::getPropertyValue( |
|
XmlParser& parser, |
|
CIMValue& cimValue) |
|
{ |
|
// Can not test for value type, so assume String |
|
const CIMType type = CIMTYPE_STRING; |
|
|
|
// Test for VALUE element |
|
if (XmlReader::getValueElement(parser, type, cimValue)) |
|
{ |
|
return true; |
|
} |
|
|
|
// Test for VALUE.ARRAY element |
|
if (XmlReader::getValueArrayElement(parser, type, cimValue)) |
|
{ |
|
return true; |
|
} |
|
|
|
// Test for VALUE.REFERENCE element |
|
CIMObjectPath reference; |
|
if (XmlReader::getValueReferenceElement(parser, reference)) |
|
{ |
|
cimValue.set(reference); |
|
return true; |
|
} |
|
|
|
// Test for VALUE.REFARRAY element |
|
if (XmlReader::getValueReferenceArrayElement(parser, cimValue)) |
|
{ |
|
return true; |
|
} |
|
|
|
return false; |
|
} |
|
|
|
//------------------------------------------------------------------------------ |
|
// |
|
// stringArrayToValue() |
|
// |
|
//------------------------------------------------------------------------------ |
|
|
|
template<class T> |
|
CIMValue StringArrayToValueAux( |
|
Uint32 lineNumber, |
|
const Array<CharString>& stringArray, |
|
CIMType type, |
|
T*) |
|
{ |
|
Array<T> array; |
|
|
|
for (Uint32 i = 0, n = stringArray.size(); i < n; i++) |
|
{ |
|
CIMValue value = XmlReader::stringToValue( |
|
lineNumber, |
|
stringArray[i].value, |
|
stringArray[i].length, |
|
type); |
|
|
|
T x; |
|
value.get(x); |
|
array.append(x); |
|
} |
|
|
|
return CIMValue(array); |
|
} |
|
|
|
CIMValue XmlReader::stringArrayToValue( |
|
Uint32 lineNumber, |
|
const Array<const char*> &array, |
|
CIMType type) |
|
{ |
|
Array<CharString> strArray; |
|
|
|
for (Uint32 i = 0, n = array.size() ; i < n ; ++i) |
|
{ |
|
strArray.append(CharString(array[i], strlen(array[i]))); |
|
} |
|
|
|
return _stringArrayToValue(lineNumber, strArray, type); |
|
} |
|
|
|
CIMValue XmlReader::_stringArrayToValue( |
|
Uint32 lineNumber, |
|
const Array<CharString> &array, |
|
CIMType type) |
|
{ |
|
switch (type) |
|
{ |
|
case CIMTYPE_BOOLEAN: |
|
return StringArrayToValueAux(lineNumber, array, type, (Boolean*)0); |
|
|
|
case CIMTYPE_STRING: |
|
return StringArrayToValueAux(lineNumber, array, type, (String*)0); |
|
|
|
case CIMTYPE_CHAR16: |
|
return StringArrayToValueAux(lineNumber, array, type, (Char16*)0); |
|
|
|
case CIMTYPE_UINT8: |
|
return StringArrayToValueAux(lineNumber, array, type, (Uint8*)0); |
|
|
|
case CIMTYPE_UINT16: |
|
return StringArrayToValueAux(lineNumber, array, type, (Uint16*)0); |
|
|
|
case CIMTYPE_UINT32: |
|
return StringArrayToValueAux(lineNumber, array, type, (Uint32*)0); |
|
|
|
case CIMTYPE_UINT64: |
|
return StringArrayToValueAux(lineNumber, array, type, (Uint64*)0); |
|
|
|
case CIMTYPE_SINT8: |
|
return StringArrayToValueAux(lineNumber, array, type, (Sint8*)0); |
|
|
|
case CIMTYPE_SINT16: |
|
return StringArrayToValueAux(lineNumber, array, type, (Sint16*)0); |
|
|
|
case CIMTYPE_SINT32: |
|
return StringArrayToValueAux(lineNumber, array, type, (Sint32*)0); |
|
|
|
case CIMTYPE_SINT64: |
|
return StringArrayToValueAux(lineNumber, array, type, (Sint64*)0); |
|
|
|
case CIMTYPE_DATETIME: |
|
return StringArrayToValueAux( |
|
lineNumber, array, type, (CIMDateTime*)0); |
|
|
|
case CIMTYPE_REAL32: |
|
return StringArrayToValueAux(lineNumber, array, type, (Real32*)0); |
|
|
|
case CIMTYPE_REAL64: |
|
return StringArrayToValueAux(lineNumber, array, type, (Real64*)0); |
|
|
|
// PEP 194: |
|
// Note that "object" (ie. CIMTYPE_OBJECT) is not a real CIM datatype, but |
|
// just a Pegasus internal representation of an embedded object. However, |
|
// this case is used when decoding string representations of embedded objects. |
|
case CIMTYPE_OBJECT: |
|
return StringArrayToValueAux( |
|
lineNumber, array, type, (CIMObject*)0); |
|
case CIMTYPE_INSTANCE: |
|
return StringArrayToValueAux( |
|
lineNumber, array, type, (CIMInstance*)0); |
|
default: |
|
break; |
|
} |
|
|
|
// Unreachable: |
|
return CIMValue(); |
|
} |
|
|
|
//------------------------------------------------------------------------------ |
|
// |
|
// getValueArrayElement() |
|
// |
|
// <!ELEMENT VALUE.ARRAY (VALUE*)> |
|
// |
|
// Return: Boolean. Returns false if there is no VALUE.ARRAY start element |
|
// |
|
//------------------------------------------------------------------------------ |
|
|
|
Boolean XmlReader::getValueArrayElement( |
|
XmlParser& parser, |
|
CIMType type, |
|
CIMValue& value) |
|
{ |
|
// Clears any values from the Array. Assumes this is array CIMValue |
|
value.clear(); |
|
|
|
// Get VALUE.ARRAY open tag: |
|
|
|
XmlEntry entry; |
|
Array<CharString> stringArray; |
|
|
|
// If no VALUE.ARRAY start tag, return false |
|
if (!testStartTagOrEmptyTag(parser, entry, "VALUE.ARRAY")) |
|
return false; |
| |
Array<const char*> stringArray; |
if (entry.type != XmlEntry::EMPTY_TAG) |
|
{ |
|
// For each VALUE element: |
| |
while (testStartTagOrEmptyTag(parser, entry, "VALUE")) | while (testStartTagOrEmptyTag(parser, entry, "VALUE")) |
{ | { |
|
// ATTN: NULL values in array will have VALUE.NULL subelement |
|
// See DSP0201 Version 2.3.0, Section 5.2.3.2 |
if (entry.type == XmlEntry::EMPTY_TAG) | if (entry.type == XmlEntry::EMPTY_TAG) |
{ | { |
stringArray.append(""); |
stringArray.append(CharString("", 0)); |
continue; | continue; |
} | } |
| |
if (testContentOrCData(parser, entry)) | if (testContentOrCData(parser, entry)) |
stringArray.append(entry.text); |
{ |
|
stringArray.append(CharString(entry.text, entry.textLen)); |
|
} |
else | else |
stringArray.append(""); |
{ |
|
stringArray.append(CharString("", 0)); |
|
} |
expectEndTag(parser, "VALUE"); | expectEndTag(parser, "VALUE"); |
} | } |
| |
expectEndTag(parser, "VALUE.ARRAY"); | expectEndTag(parser, "VALUE.ARRAY"); |
|
} |
| |
value = stringArrayToValue(parser.getLine(), stringArray, type); |
value = _stringArrayToValue(parser.getLine(), stringArray, type); |
return true; | return true; |
} | } |
| |
|
|
// | // |
//------------------------------------------------------------------------------ | //------------------------------------------------------------------------------ |
| |
Uint32 XmlReader::getFlavor( |
CIMFlavor XmlReader::getFlavor( |
XmlEntry& entry, | XmlEntry& entry, |
Uint32 lineNumber, | Uint32 lineNumber, |
const char* tagName) | const char* tagName) |
|
|
Boolean translatable = getCimBooleanAttribute( | Boolean translatable = getCimBooleanAttribute( |
lineNumber, entry, tagName, "TRANSLATABLE", false, false); | lineNumber, entry, tagName, "TRANSLATABLE", false, false); |
| |
Uint32 flavor = 0; |
// Start with CIMFlavor::NONE. Defaults are specified in the |
|
// getCimBooleanAttribute() calls above. |
|
CIMFlavor flavor = CIMFlavor (CIMFlavor::NONE); |
| |
if (overridable) | if (overridable) |
flavor |= CIMFlavor::OVERRIDABLE; |
flavor.addFlavor (CIMFlavor::OVERRIDABLE); |
|
else |
|
flavor.addFlavor (CIMFlavor::DISABLEOVERRIDE); |
| |
if (toSubClass) | if (toSubClass) |
flavor |= CIMFlavor::TOSUBCLASS; |
flavor.addFlavor (CIMFlavor::TOSUBCLASS); |
|
else |
|
flavor.addFlavor (CIMFlavor::RESTRICTED); |
| |
if (toInstance) | if (toInstance) |
flavor |= CIMFlavor::TOINSTANCE; |
flavor.addFlavor (CIMFlavor::TOINSTANCE); |
| |
if (translatable) | if (translatable) |
flavor |= CIMFlavor::TRANSLATABLE; |
flavor.addFlavor (CIMFlavor::TRANSLATABLE); |
| |
return flavor; | return flavor; |
} | } |
|
|
// | // |
//------------------------------------------------------------------------------ | //------------------------------------------------------------------------------ |
| |
Uint32 XmlReader::getOptionalScope(XmlParser& parser) |
CIMScope XmlReader::getOptionalScope(XmlParser& parser) |
{ | { |
XmlEntry entry; | XmlEntry entry; |
|
CIMScope scope; |
| |
if (!parser.next(entry)) | if (!parser.next(entry)) |
return false; |
return scope; // No SCOPE element found; return the empty scope |
| |
Boolean isEmptyTag = entry.type == XmlEntry::EMPTY_TAG; | Boolean isEmptyTag = entry.type == XmlEntry::EMPTY_TAG; |
| |
|
|
entry.type != XmlEntry::START_TAG) || | entry.type != XmlEntry::START_TAG) || |
strcmp(entry.text, "SCOPE") != 0) | strcmp(entry.text, "SCOPE") != 0) |
{ | { |
|
// No SCOPE element found; return the empty scope |
parser.putBack(entry); | parser.putBack(entry); |
return 0; |
return scope; |
} | } |
| |
Uint32 line = parser.getLine(); | Uint32 line = parser.getLine(); |
Uint32 scope = 0; |
|
| |
if (getCimBooleanAttribute(line, entry, "SCOPE", "CLASS", false, false)) | if (getCimBooleanAttribute(line, entry, "SCOPE", "CLASS", false, false)) |
scope |= CIMScope::CLASS; |
scope.addScope (CIMScope::CLASS); |
| |
if (getCimBooleanAttribute( | if (getCimBooleanAttribute( |
line, entry, "SCOPE", "ASSOCIATION", false, false)) | line, entry, "SCOPE", "ASSOCIATION", false, false)) |
scope |= CIMScope::ASSOCIATION; |
scope.addScope (CIMScope::ASSOCIATION); |
| |
if (getCimBooleanAttribute( | if (getCimBooleanAttribute( |
line, entry, "SCOPE", "REFERENCE", false, false)) | line, entry, "SCOPE", "REFERENCE", false, false)) |
scope |= CIMScope::REFERENCE; |
scope.addScope (CIMScope::REFERENCE); |
| |
if (getCimBooleanAttribute(line, entry, "SCOPE", "PROPERTY", false, false)) | if (getCimBooleanAttribute(line, entry, "SCOPE", "PROPERTY", false, false)) |
scope |= CIMScope::PROPERTY; |
scope.addScope (CIMScope::PROPERTY); |
| |
if (getCimBooleanAttribute(line, entry, "SCOPE", "METHOD", false, false)) | if (getCimBooleanAttribute(line, entry, "SCOPE", "METHOD", false, false)) |
scope |= CIMScope::METHOD; |
scope.addScope (CIMScope::METHOD); |
| |
if (getCimBooleanAttribute(line, entry, "SCOPE", "PARAMETER", false, false)) | if (getCimBooleanAttribute(line, entry, "SCOPE", "PARAMETER", false, false)) |
scope |= CIMScope::PARAMETER; |
scope.addScope (CIMScope::PARAMETER); |
| |
if (getCimBooleanAttribute(line, entry, "SCOPE", "INDICATION",false, false)) | if (getCimBooleanAttribute(line, entry, "SCOPE", "INDICATION",false, false)) |
scope |= CIMScope::INDICATION; |
scope.addScope (CIMScope::INDICATION); |
| |
if (!isEmptyTag) | if (!isEmptyTag) |
expectEndTag(parser, "SCOPE"); | expectEndTag(parser, "SCOPE"); |
|
|
// | // |
// getQualifierElement() | // getQualifierElement() |
// | // |
// <!ELEMENT QUALIFIER (VALUE|VALUE.ARRAY)> |
// <!ELEMENT QUALIFIER (VALUE|VALUE.ARRAY)?> |
// <!ATTLIST QUALIFIER | // <!ATTLIST QUALIFIER |
// %CIMName; | // %CIMName; |
// %CIMType; #REQUIRED | // %CIMType; #REQUIRED |
|
|
// Get QUALIFIER element: | // Get QUALIFIER element: |
| |
XmlEntry entry; | XmlEntry entry; |
if (!testStartTag(parser, entry, "QUALIFIER")) |
if (!testStartTagOrEmptyTag(parser, entry, "QUALIFIER")) |
return false; | return false; |
| |
|
Boolean empty = entry.type == XmlEntry::EMPTY_TAG; |
|
|
// Get QUALIFIER.NAME attribute: | // Get QUALIFIER.NAME attribute: |
| |
String name = getCimNameAttribute(parser.getLine(), entry, "QUALIFIER"); |
CIMName name = getCimNameAttribute(parser.getLine(), entry, "QUALIFIER"); |
| |
// Get QUALIFIER.TYPE attribute: | // Get QUALIFIER.TYPE attribute: |
| |
CIMType type = getCimTypeAttribute(parser.getLine(), entry, "QUALIFIER"); |
CIMType type; |
|
getCimTypeAttribute(parser.getLine(), entry, type, "QUALIFIER"); |
| |
// Get QUALIFIER.PROPAGATED | // Get QUALIFIER.PROPAGATED |
| |
|
|
| |
// Get flavor oriented attributes: | // Get flavor oriented attributes: |
| |
Uint32 flavor = getFlavor(entry, parser.getLine(), "QUALIFIER"); |
CIMFlavor flavor = getFlavor(entry, parser.getLine(), "QUALIFIER"); |
| |
// Get VALUE or VALUE.ARRAY element: | // Get VALUE or VALUE.ARRAY element: |
| |
CIMValue value; | CIMValue value; |
| |
|
if (empty) |
|
{ |
|
value.setNullValue(type, false); |
|
} |
|
else |
|
{ |
if (!getValueElement(parser, type, value) && | if (!getValueElement(parser, type, value) && |
!getValueArrayElement(parser, type, value)) | !getValueArrayElement(parser, type, value)) |
{ | { |
throw XmlSemanticError(parser.getLine(), |
value.setNullValue(type, false); |
"Expected VALUE or VALUE.ARRAY element"); |
|
} | } |
| |
// Expect </QUALIFIER>: | // Expect </QUALIFIER>: |
| |
expectEndTag(parser, "QUALIFIER"); | expectEndTag(parser, "QUALIFIER"); |
|
} |
| |
// Build qualifier: | // Build qualifier: |
| |
|
|
{ | { |
container.addQualifier(qualifier); | container.addQualifier(qualifier); |
} | } |
catch (AlreadyExists&) |
catch (AlreadyExistsException&) |
{ | { |
throw XmlSemanticError(parser.getLine(), "duplicate qualifier"); |
MessageLoaderParms mlParms( |
|
"Common.XmlReader.DUPLICATE_QUALIFIER", |
|
"duplicate qualifier"); |
|
throw XmlSemanticError(parser.getLine(), mlParms); |
} | } |
} | } |
} | } |
|
|
// %CIMName; | // %CIMName; |
// %ClassOrigin; | // %ClassOrigin; |
// %Propagated; | // %Propagated; |
|
// %EmbeddedObject; #IMPLIED |
// %CIMType; #REQUIRED> | // %CIMType; #REQUIRED> |
// | // |
//------------------------------------------------------------------------------ | //------------------------------------------------------------------------------ |
|
|
| |
// Get PROPERTY.NAME attribute: | // Get PROPERTY.NAME attribute: |
| |
String name = getCimNameAttribute(parser.getLine(), entry, "PROPERTY"); |
CIMName name = getCimNameAttribute(parser.getLine(), entry, "PROPERTY"); |
| |
// Get PROPERTY.CLASSORIGIN attribute: | // Get PROPERTY.CLASSORIGIN attribute: |
| |
String classOrigin = |
CIMName classOrigin = |
getClassOriginAttribute(parser.getLine(), entry, "PROPERTY"); | getClassOriginAttribute(parser.getLine(), entry, "PROPERTY"); |
| |
// Get PROPERTY.PROPAGATED | // Get PROPERTY.PROPAGATED |
|
|
Boolean propagated = getCimBooleanAttribute( | Boolean propagated = getCimBooleanAttribute( |
parser.getLine(), entry, "PROPERTY", "PROPAGATED", false, false); | parser.getLine(), entry, "PROPERTY", "PROPAGATED", false, false); |
| |
|
// Get PROPERTY.EmbeddedObject attribute: |
|
|
|
EmbeddedObjectAttributeType embeddedObject = |
|
getEmbeddedObjectAttribute(parser.getLine(), entry, "PROPERTY"); |
|
|
// Get PROPERTY.TYPE attribute: | // Get PROPERTY.TYPE attribute: |
| |
CIMType type = getCimTypeAttribute(parser.getLine(), entry, "PROPERTY"); |
CIMType type; |
|
getCimTypeAttribute(parser.getLine(), entry, type, "PROPERTY"); |
| |
// Create property: |
// Create property: Sets type and !isarray |
| |
CIMValue value; |
CIMValue value(type, false); |
value.setNullValue(type, false); |
property = CIMProperty(name, value, 0, CIMName(), classOrigin, propagated); |
property = CIMProperty( |
|
name, value, 0, String(), classOrigin, propagated); |
|
| |
if (!empty) | if (!empty) |
{ | { |
// Get qualifiers: |
// Get qualifiers. We need to do this before checking for the |
|
// property as an embedded object, because we need to also check |
|
// for the EmbeddedObject qualifier. |
getQualifierElements(parser, property); | getQualifierElements(parser, property); |
|
} |
| |
// Get value: |
Boolean embeddedObjectQualifierValue = false; |
|
Uint32 ix = property.findQualifier(PEGASUS_QUALIFIERNAME_EMBEDDEDOBJECT); |
|
if (ix != PEG_NOT_FOUND) |
|
{ |
|
property.getQualifier(ix).getValue().get(embeddedObjectQualifierValue); |
|
} |
|
String embeddedInstanceQualifierValue; |
|
ix = property.findQualifier(PEGASUS_QUALIFIERNAME_EMBEDDEDINSTANCE); |
|
if (ix != PEG_NOT_FOUND) |
|
{ |
|
property.getQualifier(ix).getValue().get( |
|
embeddedInstanceQualifierValue); |
|
} |
|
// If the EmbeddedObject attribute is present with value "object" |
|
// or the EmbeddedObject qualifier exists on this property with value "true" |
|
// then convert the EmbeddedObject-encoded string into a CIMObject |
|
Boolean isEmbeddedObject = (embeddedObject == EMBEDDED_OBJECT_ATTR) || |
|
embeddedObjectQualifierValue; |
|
Boolean isEmbeddedInstance = (embeddedObject == EMBEDDED_INSTANCE_ATTR) || |
|
embeddedInstanceQualifierValue.size() > 0; |
|
if (isEmbeddedObject || isEmbeddedInstance) |
|
{ |
|
// The EmbeddedObject attribute is only valid on Properties of type |
|
// string |
|
if (type == CIMTYPE_STRING) |
|
{ |
|
if (isEmbeddedObject) |
|
type = CIMTYPE_OBJECT; |
|
else |
|
type = CIMTYPE_INSTANCE; |
|
CIMValue new_value(type, false); |
|
CIMProperty new_property = CIMProperty( |
|
name, new_value, 0, CIMName(), classOrigin, propagated); |
|
|
|
// Copy the qualifiers from the String property to the CIMObject |
|
// property. |
|
for (Uint32 i = 0; i < property.getQualifierCount(); ++i) |
|
{ |
|
// All properties are copied, including the EmbeddedObject |
|
// qualifier. This way we don't have to keep track to know |
|
// that the EmbeddedObject qualifier needs to be added back |
|
// during the encode step. |
|
new_property.addQualifier(property.getQualifier(i)); |
|
} |
| |
|
value = new_value; |
|
property = new_property; |
|
} |
|
else |
|
{ |
|
MessageLoaderParms mlParms( |
|
"Common.XmlReader.INVALID_EMBEDDEDOBJECT_TYPE", |
|
"The EmbeddedObject attribute is only valid on string types."); |
|
throw XmlValidationError(parser.getLine(), mlParms); |
|
} |
|
} |
|
// Continue on to get property value, if not empty. |
|
if (!empty) |
|
{ |
if (getValueElement(parser, type, value)) | if (getValueElement(parser, type, value)) |
property.setValue(value); | property.setValue(value); |
|
|
expectEndTag(parser, "PROPERTY"); | expectEndTag(parser, "PROPERTY"); |
} | } |
| |
|
|
| |
Uint64 arraySize; | Uint64 arraySize; |
| |
if (!stringToUnsignedInteger(tmp, arraySize) || arraySize == 0) |
if (!StringConversion::stringToUnsignedInteger(tmp, arraySize) || |
|
(arraySize == 0) || |
|
!StringConversion::checkUintBounds(arraySize, CIMTYPE_UINT32)) |
{ | { |
char message[128]; | char message[128]; |
sprintf(message, "Illegal value for %s.%s", tagName, "ARRAYSIZE"); |
sprintf(message, "%s.%s", tagName, "ARRAYSIZE"); |
throw XmlSemanticError(lineNumber, message); |
|
|
MessageLoaderParms mlParms( |
|
"Common.XmlReader.ILLEGAL_VALUE", |
|
"Illegal value for $0", |
|
message); |
|
throw XmlSemanticError(lineNumber, mlParms); |
} | } |
| |
value = Uint32(arraySize); | value = Uint32(arraySize); |
|
|
// %CIMType; #REQUIRED | // %CIMType; #REQUIRED |
// %ArraySize; | // %ArraySize; |
// %ClassOrigin; | // %ClassOrigin; |
// %Propagated;> |
// %Propagated; |
|
// %EmbeddedObject; #IMPLIED> |
// | // |
//------------------------------------------------------------------------------ | //------------------------------------------------------------------------------ |
| |
|
|
| |
// Get PROPERTY.NAME attribute: | // Get PROPERTY.NAME attribute: |
| |
String name = |
CIMName name = |
getCimNameAttribute(parser.getLine(), entry, "PROPERTY.ARRAY"); | getCimNameAttribute(parser.getLine(), entry, "PROPERTY.ARRAY"); |
| |
// Get PROPERTY.TYPE attribute: | // Get PROPERTY.TYPE attribute: |
| |
CIMType type = getCimTypeAttribute(parser.getLine(), entry, "PROPERTY.ARRAY"); |
CIMType type; |
|
getCimTypeAttribute(parser.getLine(), entry, type, "PROPERTY.ARRAY"); |
| |
// Get PROPERTY.ARRAYSIZE attribute: | // Get PROPERTY.ARRAYSIZE attribute: |
| |
|
|
| |
// Get PROPERTY.CLASSORIGIN attribute: | // Get PROPERTY.CLASSORIGIN attribute: |
| |
String classOrigin |
CIMName classOrigin = |
= getClassOriginAttribute(parser.getLine(), entry, "PROPERTY.ARRAY"); |
getClassOriginAttribute(parser.getLine(), entry, "PROPERTY.ARRAY"); |
| |
// Get PROPERTY.ARRAY.PROPAGATED | // Get PROPERTY.ARRAY.PROPAGATED |
| |
Boolean propagated = getCimBooleanAttribute( | Boolean propagated = getCimBooleanAttribute( |
parser.getLine(), entry, "PROPERTY.ARRAY", "PROPAGATED", false, false); |
parser.getLine(), |
|
entry, |
|
"PROPERTY.ARRAY", |
|
"PROPAGATED", |
|
false, |
|
false); |
|
|
|
// Get PROPERTY.EmbeddedObject attribute: |
|
|
|
EmbeddedObjectAttributeType embeddedObject = getEmbeddedObjectAttribute( |
|
parser.getLine(), entry, "PROPERTY.ARRAY"); |
| |
// Create property: | // Create property: |
| |
CIMValue nullValue; |
CIMValue value(type, true, arraySize); |
nullValue.setNullValue(type, true, arraySize); |
|
property = CIMProperty( | property = CIMProperty( |
name, nullValue, arraySize, String(), classOrigin, propagated); |
name, value, arraySize, CIMName(), classOrigin, propagated); |
| |
if (!empty) | if (!empty) |
{ | { |
// Get qualifiers: | // Get qualifiers: |
|
|
getQualifierElements(parser, property); | getQualifierElements(parser, property); |
|
} |
| |
// Get value: |
Boolean embeddedObjectQualifierValue = false; |
|
Uint32 ix = property.findQualifier(PEGASUS_QUALIFIERNAME_EMBEDDEDOBJECT); |
CIMValue value; |
if (ix != PEG_NOT_FOUND) |
|
{ |
|
property.getQualifier(ix).getValue().get(embeddedObjectQualifierValue); |
|
} |
|
String embeddedInstanceQualifierValue; |
|
ix = property.findQualifier(PEGASUS_QUALIFIERNAME_EMBEDDEDINSTANCE); |
|
if (ix != PEG_NOT_FOUND) |
|
{ |
|
property.getQualifier(ix).getValue().get( |
|
embeddedInstanceQualifierValue); |
|
} |
|
// If the EmbeddedObject attribute is present with value "object" |
|
// or the EmbeddedObject qualifier exists on this property with value "true" |
|
// then |
|
// Convert the EmbeddedObject-encoded string into a CIMObject |
|
Boolean isEmbeddedObject = (embeddedObject == EMBEDDED_OBJECT_ATTR) || |
|
embeddedObjectQualifierValue; |
|
Boolean isEmbeddedInstance = (embeddedObject == EMBEDDED_INSTANCE_ATTR) || |
|
embeddedInstanceQualifierValue.size() > 0; |
|
if (isEmbeddedObject || isEmbeddedInstance) |
|
{ |
|
// The EmbeddedObject attribute is only valid on Properties of type |
|
// string |
|
if (type == CIMTYPE_STRING) |
|
{ |
|
if (isEmbeddedObject) |
|
type = CIMTYPE_OBJECT; |
|
else |
|
type = CIMTYPE_INSTANCE; |
|
CIMValue new_value(type, true, arraySize); |
|
CIMProperty new_property = CIMProperty( |
|
name, new_value, arraySize, CIMName(), classOrigin, propagated); |
|
|
|
// Copy the qualifiers from the String property to the CIMObject |
|
// property. |
|
for (Uint32 i = 0; i < property.getQualifierCount(); ++i) |
|
{ |
|
// All properties are copied, including the EmbeddedObject |
|
// qualifier. This way we don't have to keep track to know |
|
// that the EmbeddedObject qualifier needs to be added back |
|
// during the encode step. |
|
new_property.addQualifier(property.getQualifier(i)); |
|
} |
| |
|
value = new_value; |
|
property = new_property; |
|
} |
|
else |
|
{ |
|
MessageLoaderParms mlParms( |
|
"Common.XmlReader.INVALID_EMBEDDEDOBJECT_TYPE", |
|
"The EmbeddedObject attribute is only valid on string types."); |
|
throw XmlValidationError(parser.getLine(), mlParms); |
|
} |
|
} |
|
// Continue on to get property array value, if not empty. |
|
// Else not an embedded object, if not empty, get the property array value. |
|
if (!empty) |
|
{ |
if (getValueArrayElement(parser, type, value)) | if (getValueArrayElement(parser, type, value)) |
{ | { |
if (arraySize && arraySize != value.getArraySize()) | if (arraySize && arraySize != value.getArraySize()) |
{ | { |
throw XmlSemanticError(parser.getLine(), |
MessageLoaderParms mlParms( |
|
"Common.XmlReader.ARRAY_SIZE_DIFFERENT", |
"ARRAYSIZE attribute and value-array size are different"); | "ARRAYSIZE attribute and value-array size are different"); |
|
throw XmlSemanticError(parser.getLine(), mlParms); |
} | } |
| |
property.setValue(value); | property.setValue(value); |
} | } |
|
|
expectEndTag(parser, "PROPERTY.ARRAY"); | expectEndTag(parser, "PROPERTY.ARRAY"); |
} | } |
| |
|
|
| |
if (!parser.next(entry) || entry.type != XmlEntry::CONTENT) | if (!parser.next(entry) || entry.type != XmlEntry::CONTENT) |
{ | { |
throw XmlValidationError(parser.getLine(), |
MessageLoaderParms mlParms( |
|
"Common.XmlReader.EXPECTED_CONTENT_ELEMENT", |
"expected content of HOST element"); | "expected content of HOST element"); |
|
throw XmlValidationError(parser.getLine(), mlParms); |
} | } |
| |
host = entry.text; |
host = String(entry.text); |
|
|
expectEndTag(parser, "HOST"); | expectEndTag(parser, "HOST"); |
return true; | return true; |
} | } |
|
|
| |
Boolean XmlReader::getNameSpaceElement( | Boolean XmlReader::getNameSpaceElement( |
XmlParser& parser, | XmlParser& parser, |
String& nameSpaceComponent) |
CIMName& nameSpaceComponent) |
{ | { |
XmlEntry entry; | XmlEntry entry; |
| |
|
|
if (!testStartTag(parser, entry, "LOCALNAMESPACEPATH")) | if (!testStartTag(parser, entry, "LOCALNAMESPACEPATH")) |
return false; | return false; |
| |
String nameSpaceComponent; |
CIMName nameSpaceComponent; |
| |
while (getNameSpaceElement(parser, nameSpaceComponent)) | while (getNameSpaceElement(parser, nameSpaceComponent)) |
{ | { |
if (nameSpace.size()) | if (nameSpace.size()) |
nameSpace += '/'; |
nameSpace.append('/'); |
| |
nameSpace += nameSpaceComponent; |
nameSpace.append(nameSpaceComponent.getString()); |
} | } |
| |
if (!nameSpace.size()) | if (!nameSpace.size()) |
{ | { |
throw XmlValidationError(parser.getLine(), |
MessageLoaderParms mlParms( |
|
"Common.XmlReader.EXPECTED_NAMESPACE_ELEMENTS", |
"Expected one or more NAMESPACE elements within " | "Expected one or more NAMESPACE elements within " |
"LOCALNAMESPACEPATH element"); | "LOCALNAMESPACEPATH element"); |
|
throw XmlValidationError(parser.getLine(), mlParms); |
} | } |
| |
expectEndTag(parser, "LOCALNAMESPACEPATH"); | expectEndTag(parser, "LOCALNAMESPACEPATH"); |
|
|
return false; | return false; |
| |
if (!getHostElement(parser, host)) | if (!getHostElement(parser, host)) |
throw XmlValidationError(parser.getLine(), "expected HOST element"); |
{ |
|
MessageLoaderParms mlParms( |
|
"Common.XmlReader.EXPECTED_HOST_ELEMENT", |
|
"expected HOST element"); |
|
throw XmlValidationError(parser.getLine(), mlParms); |
|
} |
| |
if (!getLocalNameSpacePathElement(parser, nameSpace)) | if (!getLocalNameSpacePathElement(parser, nameSpace)) |
{ | { |
throw XmlValidationError(parser.getLine(), |
MessageLoaderParms mlParms( |
|
"Common.XmlReader.EXPECTED_LOCALNAMESPACEPATH_ELEMENT", |
"expected LOCALNAMESPACEPATH element"); | "expected LOCALNAMESPACEPATH element"); |
|
throw XmlValidationError(parser.getLine(), mlParms); |
} | } |
| |
expectEndTag(parser, "NAMESPACEPATH"); | expectEndTag(parser, "NAMESPACEPATH"); |
|
|
| |
Boolean XmlReader::getClassNameElement( | Boolean XmlReader::getClassNameElement( |
XmlParser& parser, | XmlParser& parser, |
String& className, |
CIMName& className, |
Boolean required) | Boolean required) |
{ | { |
XmlEntry entry; | XmlEntry entry; |
|
|
{ | { |
if (required) | if (required) |
{ | { |
throw XmlValidationError(parser.getLine(), |
MessageLoaderParms mlParms( |
|
"Common.XmlReader.EXPECTED_CLASSNAME_ELEMENT", |
"expected CLASSNAME element"); | "expected CLASSNAME element"); |
|
throw XmlValidationError(parser.getLine(), mlParms); |
} | } |
else | else |
return false; | return false; |
} | } |
|
|
Boolean empty = entry.type == XmlEntry::EMPTY_TAG; | Boolean empty = entry.type == XmlEntry::EMPTY_TAG; |
| |
className = getCimNameAttribute( | className = getCimNameAttribute( |
parser.getLine(), entry, "CLASSNAME", true); |
parser.getLine(), entry, "CLASSNAME", false); |
| |
if (!empty) | if (!empty) |
expectEndTag(parser, "CLASSNAME"); | expectEndTag(parser, "CLASSNAME"); |
|
|
// | // |
//------------------------------------------------------------------------------ | //------------------------------------------------------------------------------ |
| |
KeyBinding::Type XmlReader::getValueTypeAttribute( |
CIMKeyBinding::Type XmlReader::getValueTypeAttribute( |
Uint32 lineNumber, | Uint32 lineNumber, |
const XmlEntry& entry, | const XmlEntry& entry, |
const char* elementName) | const char* elementName) |
{ | { |
String tmp; |
const char* tmp; |
| |
if (!entry.getAttributeValue("VALUETYPE", tmp)) | if (!entry.getAttributeValue("VALUETYPE", tmp)) |
return KeyBinding::STRING; |
return CIMKeyBinding::STRING; |
| |
if (String::equal(tmp, "string")) |
if (strcmp(tmp, "string") == 0) |
return KeyBinding::STRING; |
return CIMKeyBinding::STRING; |
else if (String::equal(tmp, "boolean")) |
else if (strcmp(tmp, "boolean") == 0) |
return KeyBinding::BOOLEAN; |
return CIMKeyBinding::BOOLEAN; |
else if (String::equal(tmp, "numeric")) |
else if (strcmp(tmp, "numeric") == 0) |
return KeyBinding::NUMERIC; |
return CIMKeyBinding::NUMERIC; |
| |
char buffer[MESSAGE_SIZE]; | char buffer[MESSAGE_SIZE]; |
|
sprintf(buffer, "%s.VALUETYPE", elementName); |
| |
sprintf(buffer, |
MessageLoaderParms mlParms( |
"Illegal value for %s.VALUETYPE attribute; " |
"Common.XmlReader.ILLEGAL_VALUE_FOR_CIMVALUE_ATTRIBUTE", |
"CIMValue must be one of \"string\", \"boolean\", or \"numeric\"", |
"Illegal value for $0 attribute; CIMValue must be one of \"string\", " |
elementName); |
"\"boolean\", or \"numeric\"", |
|
buffer); |
|
throw XmlSemanticError(lineNumber, mlParms); |
| |
throw XmlSemanticError(lineNumber, buffer); |
return CIMKeyBinding::BOOLEAN; |
return KeyBinding::BOOLEAN; |
|
} | } |
| |
//------------------------------------------------------------------------------ | //------------------------------------------------------------------------------ |
|
|
// <!ATTLIST KEYVALUE | // <!ATTLIST KEYVALUE |
// VALUETYPE (string|boolean|numeric) 'string'> | // VALUETYPE (string|boolean|numeric) 'string'> |
// | // |
// ATTN-B: VALUE.REFERENCE ignored above; can't understand why it is needed! |
|
// |
|
//------------------------------------------------------------------------------ | //------------------------------------------------------------------------------ |
| |
Boolean XmlReader::getKeyValueElement( | Boolean XmlReader::getKeyValueElement( |
XmlParser& parser, | XmlParser& parser, |
KeyBinding::Type& type, |
CIMKeyBinding::Type& type, |
String& value) | String& value) |
{ | { |
XmlEntry entry; | XmlEntry entry; |
|
|
throw XmlException(XmlException::UNCLOSED_TAGS, parser.getLine()); | throw XmlException(XmlException::UNCLOSED_TAGS, parser.getLine()); |
| |
if (entry.type == XmlEntry::CONTENT) | if (entry.type == XmlEntry::CONTENT) |
value = entry.text; |
value = String(entry.text); |
else | else |
parser.putBack(entry); | parser.putBack(entry); |
| |
|
|
// <!ATTLIST KEYBINDING | // <!ATTLIST KEYBINDING |
// %CIMName;> | // %CIMName;> |
// | // |
// ATTN-B: VALUE.REFERENCE ignored above; can't understand why it is needed! |
|
// |
|
//------------------------------------------------------------------------------ | //------------------------------------------------------------------------------ |
| |
Boolean XmlReader::getKeyBindingElement( | Boolean XmlReader::getKeyBindingElement( |
XmlParser& parser, | XmlParser& parser, |
String& name, |
CIMName& name, |
String& value, | String& value, |
KeyBinding::Type& type) |
CIMKeyBinding::Type& type) |
{ | { |
XmlEntry entry; | XmlEntry entry; |
| |
|
|
name = getCimNameAttribute(parser.getLine(), entry, "KEYBINDING"); | name = getCimNameAttribute(parser.getLine(), entry, "KEYBINDING"); |
| |
if (!getKeyValueElement(parser, type, value)) | if (!getKeyValueElement(parser, type, value)) |
throw XmlValidationError(parser.getLine(), "Expected KEYVALUE element"); |
{ |
|
CIMObjectPath reference; |
|
|
|
if (!getValueReferenceElement(parser, reference)) |
|
{ |
|
MessageLoaderParms mlParms( |
|
"Common.XmlReader.EXPECTED_KEYVALUE_OR_REFERENCE_ELEMENT", |
|
"Expected KEYVALUE or VALUE.REFERENCE element"); |
|
throw XmlValidationError(parser.getLine(), mlParms); |
|
} |
|
|
|
type = CIMKeyBinding::REFERENCE; |
|
value = reference.toString(); |
|
} |
| |
expectEndTag(parser, "KEYBINDING"); | expectEndTag(parser, "KEYBINDING"); |
return true; | return true; |
|
|
// <!ATTLIST INSTANCENAME | // <!ATTLIST INSTANCENAME |
// %ClassName;> | // %ClassName;> |
// | // |
// ATTN-B: VALUE.REFERENCE sub-element not accepted yet. |
// Note: An empty key name is used in the keyBinding when the INSTANCENAME is |
// ATTN-B: KEYVALUE sub-element nothandled yet. |
// specified using a KEYVALUE or a VALUE.REFERENCE. |
// | // |
//------------------------------------------------------------------------------ | //------------------------------------------------------------------------------ |
| |
Boolean XmlReader::getInstanceNameElement( | Boolean XmlReader::getInstanceNameElement( |
XmlParser& parser, | XmlParser& parser, |
String& className, | String& className, |
Array<KeyBinding>& keyBindings) |
Array<CIMKeyBinding>& keyBindings) |
{ | { |
className.clear(); | className.clear(); |
keyBindings.clear(); | keyBindings.clear(); |
|
|
| |
className = getClassNameAttribute(parser.getLine(), entry, "INSTANCENAME"); | className = getClassNameAttribute(parser.getLine(), entry, "INSTANCENAME"); |
| |
if (!empty) |
if (empty) |
{ | { |
String name; |
return true; |
KeyBinding::Type type; |
} |
|
|
|
CIMName name; |
|
CIMKeyBinding::Type type; |
String value; | String value; |
|
CIMObjectPath reference; |
| |
|
if (getKeyValueElement(parser, type, value)) |
|
{ |
|
// Use empty key name because none was specified |
|
keyBindings.append(CIMKeyBinding(name, value, type)); |
|
} |
|
else if (getValueReferenceElement(parser, reference)) |
|
{ |
|
// Use empty key name because none was specified |
|
type = CIMKeyBinding::REFERENCE; |
|
value = reference.toString(); |
|
keyBindings.append(CIMKeyBinding(name, value, type)); |
|
} |
|
else |
|
{ |
while (getKeyBindingElement(parser, name, value, type)) | while (getKeyBindingElement(parser, name, value, type)) |
keyBindings.append(KeyBinding(name, value, type)); |
{ |
|
keyBindings.append(CIMKeyBinding(name, value, type)); |
|
if (keyBindings.size() > PEGASUS_MAXELEMENTS_NUM) |
|
{ |
|
MessageLoaderParms mlParms( |
|
"Common.XmlReader.TOO_MANY_KEYBINDINGS", |
|
"More than $0 key-value pairs per object path" |
|
" are not supported.", |
|
PEGASUS_MAXELEMENTS_NUM); |
|
throw XmlValidationError(parser.getLine(), mlParms); |
|
} |
|
} |
|
} |
| |
if (!empty) |
|
expectEndTag(parser, "INSTANCENAME"); | expectEndTag(parser, "INSTANCENAME"); |
|
|
|
return true; |
} | } |
| |
|
Boolean XmlReader::getInstanceNameElement( |
|
XmlParser& parser, |
|
CIMObjectPath& instanceName) |
|
{ |
|
String className; |
|
Array<CIMKeyBinding> keyBindings; |
|
|
|
if (!XmlReader::getInstanceNameElement(parser, className, keyBindings)) |
|
return false; |
|
|
|
instanceName.set(String(), CIMNamespaceName(), className, keyBindings); |
return true; | return true; |
} | } |
| |
|
|
| |
Boolean XmlReader::getInstancePathElement( | Boolean XmlReader::getInstancePathElement( |
XmlParser& parser, | XmlParser& parser, |
CIMReference& reference) |
CIMObjectPath& reference) |
{ | { |
XmlEntry entry; | XmlEntry entry; |
| |
|
|
| |
if (!getNameSpacePathElement(parser, host, nameSpace)) | if (!getNameSpacePathElement(parser, host, nameSpace)) |
{ | { |
throw XmlValidationError(parser.getLine(), |
MessageLoaderParms mlParms( |
|
"Common.XmlReader.EXPECTED_NAMESPACEPATH_ELEMENT", |
"expected NAMESPACEPATH element"); | "expected NAMESPACEPATH element"); |
|
throw XmlValidationError(parser.getLine(), mlParms); |
} | } |
| |
String className; | String className; |
Array<KeyBinding> keyBindings; |
Array<CIMKeyBinding> keyBindings; |
| |
if (!getInstanceNameElement(parser, className, keyBindings)) | if (!getInstanceNameElement(parser, className, keyBindings)) |
{ | { |
throw XmlValidationError(parser.getLine(), |
MessageLoaderParms mlParms( |
|
"Common.XmlReader.EXPECTED_INSTANCENAME_ELEMENT", |
"expected INSTANCENAME element"); | "expected INSTANCENAME element"); |
|
throw XmlValidationError(parser.getLine(), mlParms); |
} | } |
| |
reference.set(host, nameSpace, className, keyBindings); | reference.set(host, nameSpace, className, keyBindings); |
|
|
| |
Boolean XmlReader::getLocalInstancePathElement( | Boolean XmlReader::getLocalInstancePathElement( |
XmlParser& parser, | XmlParser& parser, |
CIMReference& reference) |
CIMObjectPath& reference) |
{ | { |
XmlEntry entry; | XmlEntry entry; |
| |
|
|
| |
if (!getLocalNameSpacePathElement(parser, nameSpace)) | if (!getLocalNameSpacePathElement(parser, nameSpace)) |
{ | { |
throw XmlValidationError(parser.getLine(), |
MessageLoaderParms mlParms( |
|
"Common.XmlReader.EXPECTED_LOCALNAMESPACEPATH_ELEMENT", |
"expected LOCALNAMESPACEPATH element"); | "expected LOCALNAMESPACEPATH element"); |
|
throw XmlValidationError(parser.getLine(), mlParms); |
} | } |
| |
String className; | String className; |
Array<KeyBinding> keyBindings; |
Array<CIMKeyBinding> keyBindings; |
| |
if (!getInstanceNameElement(parser, className, keyBindings)) | if (!getInstanceNameElement(parser, className, keyBindings)) |
{ | { |
throw XmlValidationError(parser.getLine(), |
MessageLoaderParms mlParms( |
|
"Common.XmlReader.EXPECTED_INSTANCENAME_ELEMENT", |
"expected INSTANCENAME element"); | "expected INSTANCENAME element"); |
|
throw XmlValidationError(parser.getLine(), mlParms); |
} | } |
| |
reference.set(String(), nameSpace, className, keyBindings); | reference.set(String(), nameSpace, className, keyBindings); |
|
|
| |
Boolean XmlReader::getClassPathElement( | Boolean XmlReader::getClassPathElement( |
XmlParser& parser, | XmlParser& parser, |
CIMReference& reference) |
CIMObjectPath& reference) |
{ | { |
XmlEntry entry; | XmlEntry entry; |
| |
|
|
| |
if (!getNameSpacePathElement(parser, host, nameSpace)) | if (!getNameSpacePathElement(parser, host, nameSpace)) |
{ | { |
throw XmlValidationError(parser.getLine(), |
MessageLoaderParms mlParms( |
|
"Common.XmlReader.EXPECTED_NAMESPACEPATH_ELEMENT", |
"expected NAMESPACEPATH element"); | "expected NAMESPACEPATH element"); |
|
throw XmlValidationError(parser.getLine(), mlParms); |
} | } |
| |
String className; |
CIMName className; |
| |
if (!getClassNameElement(parser, className)) | if (!getClassNameElement(parser, className)) |
{ | { |
throw XmlValidationError(parser.getLine(), |
MessageLoaderParms mlParms( |
|
"Common.XmlReader.EXPECTED_CLASSNAME_ELEMENT", |
"expected CLASSNAME element"); | "expected CLASSNAME element"); |
|
throw XmlValidationError(parser.getLine(), mlParms); |
} | } |
| |
reference.set(host, nameSpace, className); | reference.set(host, nameSpace, className); |
|
|
| |
Boolean XmlReader::getLocalClassPathElement( | Boolean XmlReader::getLocalClassPathElement( |
XmlParser& parser, | XmlParser& parser, |
CIMReference& reference) |
CIMObjectPath& reference) |
{ | { |
XmlEntry entry; | XmlEntry entry; |
| |
|
|
| |
if (!getLocalNameSpacePathElement(parser, nameSpace)) | if (!getLocalNameSpacePathElement(parser, nameSpace)) |
{ | { |
throw XmlValidationError(parser.getLine(), |
MessageLoaderParms mlParms( |
|
"Common.XmlReader.EXPECTED_LOCALNAMESPACEPATH_ELEMENT", |
"expected LOCALNAMESPACEPATH element"); | "expected LOCALNAMESPACEPATH element"); |
|
throw XmlValidationError(parser.getLine(), mlParms); |
} | } |
| |
String className; |
CIMName className; |
| |
if (!getClassNameElement(parser, className)) | if (!getClassNameElement(parser, className)) |
{ | { |
throw XmlValidationError(parser.getLine(), |
MessageLoaderParms mlParms( |
|
"Common.XmlReader.EXPECTED_CLASSNAME_ELEMENT", |
"expected CLASSNAME element"); | "expected CLASSNAME element"); |
|
throw XmlValidationError(parser.getLine(), mlParms); |
} | } |
| |
reference.set(String(), nameSpace, className); | reference.set(String(), nameSpace, className); |
|
|
// | // |
// | // |
//------------------------------------------------------------------------------ | //------------------------------------------------------------------------------ |
|
// |
|
// Parses the input to a CIMObjectPath. Note that today the differences |
|
// between ClassPath and InstancePath are lost in this mapping because |
|
// Pegasus uses the existence of keys as separator . See BUG_3302 |
Boolean XmlReader::getValueReferenceElement( | Boolean XmlReader::getValueReferenceElement( |
XmlParser& parser, | XmlParser& parser, |
CIMReference& reference) |
CIMObjectPath& reference) |
{ | { |
XmlEntry entry; | XmlEntry entry; |
| |
|
|
if (entry.type != XmlEntry::START_TAG && | if (entry.type != XmlEntry::START_TAG && |
entry.type != XmlEntry::EMPTY_TAG) | entry.type != XmlEntry::EMPTY_TAG) |
{ | { |
throw XmlValidationError(parser.getLine(), |
MessageLoaderParms mlParms( |
"Expected one of the following start tags: " |
"Common.XmlReader.EXPECTED_START_TAGS", |
"CLASSPATH, LOCALCLASSPATH, CLASSNAME, INSTANCEPATH, " |
"Expected one of the following start tags: CLASSPATH, " |
"LOCALINSTANCEPATH, INSTANCENAME"); |
"LOCALCLASSPATH, CLASSNAME, INSTANCEPATH, LOCALINSTANCEPATH, " |
|
"INSTANCENAME"); |
|
throw XmlValidationError(parser.getLine(), mlParms); |
} | } |
| |
if (strcmp(entry.text, "CLASSPATH") == 0) | if (strcmp(entry.text, "CLASSPATH") == 0) |
|
|
else if (strcmp(entry.text, "CLASSNAME") == 0) | else if (strcmp(entry.text, "CLASSNAME") == 0) |
{ | { |
parser.putBack(entry); | parser.putBack(entry); |
String className; |
CIMName className; |
getClassNameElement(parser, className); | getClassNameElement(parser, className); |
reference.set(String(), String(), className); |
reference.set(String(), CIMNamespaceName(), className); |
} | } |
else if (strcmp(entry.text, "INSTANCEPATH") == 0) | else if (strcmp(entry.text, "INSTANCEPATH") == 0) |
{ | { |
|
|
{ | { |
parser.putBack(entry); | parser.putBack(entry); |
String className; | String className; |
Array<KeyBinding> keyBindings; |
Array<CIMKeyBinding> keyBindings; |
getInstanceNameElement(parser, className, keyBindings); | getInstanceNameElement(parser, className, keyBindings); |
reference.set(String(), String(), className, keyBindings); |
reference.set(String(), CIMNamespaceName(), className, keyBindings); |
} | } |
| |
expectEndTag(parser, "VALUE.REFERENCE"); | expectEndTag(parser, "VALUE.REFERENCE"); |
|
|
| |
//------------------------------------------------------------------------------ | //------------------------------------------------------------------------------ |
// | // |
|
// getValueReferenceArrayElement() |
|
// |
|
// <!ELEMENT VALUE.REFARRAY (VALUE.REFERENCE*)> |
|
// |
|
//------------------------------------------------------------------------------ |
|
|
|
Boolean XmlReader::getValueReferenceArrayElement( |
|
XmlParser& parser, |
|
CIMValue& value) |
|
{ |
|
XmlEntry entry; |
|
Array<CIMObjectPath> referenceArray; |
|
CIMObjectPath reference; |
|
|
|
value.clear(); |
|
|
|
// Get VALUE.REFARRAY open tag: |
|
|
|
if (!testStartTagOrEmptyTag(parser, entry, "VALUE.REFARRAY")) |
|
return false; |
|
|
|
if (entry.type != XmlEntry::EMPTY_TAG) |
|
{ |
|
// For each VALUE.REFERENCE element: |
|
|
|
while (getValueReferenceElement(parser, reference)) |
|
{ |
|
referenceArray.append(reference); |
|
} |
|
|
|
expectEndTag(parser, "VALUE.REFARRAY"); |
|
} |
|
|
|
value.set(referenceArray); |
|
return true; |
|
} |
|
|
|
//------------------------------------------------------------------------------ |
|
// |
// getPropertyReferenceElement() | // getPropertyReferenceElement() |
// | // |
// <!ELEMENT PROPERTY.REFERENCE (QUALIFIER*,(VALUE.REFERENCE)?)> | // <!ELEMENT PROPERTY.REFERENCE (QUALIFIER*,(VALUE.REFERENCE)?)> |
|
|
| |
// Get PROPERTY.NAME attribute: | // Get PROPERTY.NAME attribute: |
| |
String name = getCimNameAttribute( |
CIMName name = getCimNameAttribute( |
parser.getLine(), entry, "PROPERTY.REFERENCE"); | parser.getLine(), entry, "PROPERTY.REFERENCE"); |
| |
// Get PROPERTY.REFERENCECLASS attribute: | // Get PROPERTY.REFERENCECLASS attribute: |
| |
String referenceClass = getReferenceClassAttribute( |
CIMName referenceClass = getReferenceClassAttribute( |
parser.getLine(), entry, "PROPERTY.REFERENCE"); | parser.getLine(), entry, "PROPERTY.REFERENCE"); |
| |
// Get PROPERTY.CLASSORIGIN attribute: | // Get PROPERTY.CLASSORIGIN attribute: |
| |
String classOrigin = |
CIMName classOrigin = |
getClassOriginAttribute(parser.getLine(), entry, "PROPERTY.REFERENCE"); | getClassOriginAttribute(parser.getLine(), entry, "PROPERTY.REFERENCE"); |
| |
// Get PROPERTY.PROPAGATED | // Get PROPERTY.PROPAGATED |
|
|
| |
// Create property: | // Create property: |
| |
CIMValue value; |
CIMValue value = CIMValue(CIMTYPE_REFERENCE, false, 0); |
value.set(CIMReference()); |
// value.set(CIMObjectPath()); |
property = CIMProperty( | property = CIMProperty( |
name, value, 0, referenceClass, classOrigin, propagated); | name, value, 0, referenceClass, classOrigin, propagated); |
| |
|
|
{ | { |
getQualifierElements(parser, property); | getQualifierElements(parser, property); |
| |
CIMReference reference; |
CIMObjectPath reference; |
| |
if (getValueReferenceElement(parser, reference)) | if (getValueReferenceElement(parser, reference)) |
property.setValue(reference); | property.setValue(reference); |
|
|
{ | { |
container.addProperty(property); | container.addProperty(property); |
} | } |
catch (AlreadyExists&) |
catch (AlreadyExistsException&) |
{ | { |
throw XmlSemanticError(parser.getLine(), "duplicate property"); |
MessageLoaderParms mlParms( |
|
"Common.XmlReader.DUPLICATE_PROPERTY", |
|
"duplicate property"); |
|
throw XmlSemanticError(parser.getLine(), mlParms); |
} | } |
} | } |
} | } |
|
|
| |
// Get PARAMETER.NAME attribute: | // Get PARAMETER.NAME attribute: |
| |
String name = getCimNameAttribute(parser.getLine(), entry, "PARAMETER"); |
CIMName name = getCimNameAttribute(parser.getLine(), entry, "PARAMETER"); |
| |
// Get PARAMETER.TYPE attribute: | // Get PARAMETER.TYPE attribute: |
| |
CIMType type = getCimTypeAttribute(parser.getLine(), entry, "PARAMETER"); |
CIMType type; |
|
getCimTypeAttribute(parser.getLine(), entry, type, "PARAMETER"); |
| |
// Create parameter: | // Create parameter: |
| |
|
|
| |
// Get PARAMETER.ARRAY.NAME attribute: | // Get PARAMETER.ARRAY.NAME attribute: |
| |
String name = getCimNameAttribute( |
CIMName name = getCimNameAttribute( |
parser.getLine(), entry, "PARAMETER.ARRAY"); | parser.getLine(), entry, "PARAMETER.ARRAY"); |
| |
// Get PARAMETER.ARRAY.TYPE attribute: | // Get PARAMETER.ARRAY.TYPE attribute: |
| |
CIMType type = getCimTypeAttribute(parser.getLine(), entry, "PARAMETER.ARRAY"); |
CIMType type; |
|
getCimTypeAttribute(parser.getLine(), entry, type, "PARAMETER.ARRAY"); |
| |
// Get PARAMETER.ARRAYSIZE attribute: | // Get PARAMETER.ARRAYSIZE attribute: |
| |
|
|
| |
// Get PARAMETER.NAME attribute: | // Get PARAMETER.NAME attribute: |
| |
String name = getCimNameAttribute( |
CIMName name = getCimNameAttribute( |
parser.getLine(), entry, "PARAMETER.REFERENCE"); | parser.getLine(), entry, "PARAMETER.REFERENCE"); |
| |
// Get PARAMETER.REFERENCECLASS attribute: | // Get PARAMETER.REFERENCECLASS attribute: |
| |
String referenceClass = getReferenceClassAttribute( |
CIMName referenceClass = getReferenceClassAttribute( |
parser.getLine(), entry, "PARAMETER.REFERENCE"); | parser.getLine(), entry, "PARAMETER.REFERENCE"); |
| |
// Create parameter: | // Create parameter: |
| |
parameter = CIMParameter(name, CIMType::REFERENCE, false, 0, referenceClass); |
parameter = CIMParameter(name, CIMTYPE_REFERENCE, false, 0, referenceClass); |
| |
if (!empty) | if (!empty) |
{ | { |
|
|
| |
//------------------------------------------------------------------------------ | //------------------------------------------------------------------------------ |
// | // |
|
// getParameterReferenceArrayElement() |
|
// |
|
// <!ELEMENT PARAMETER.REFARRAY (QUALIFIER*)> |
|
// <!ATTLIST PARAMETER.REFARRAY |
|
// %CIMName; |
|
// %ReferenceClass; |
|
// %ArraySize;> |
|
// |
|
//------------------------------------------------------------------------------ |
|
|
|
Boolean XmlReader::getParameterReferenceArrayElement( |
|
XmlParser& parser, |
|
CIMParameter& parameter) |
|
{ |
|
XmlEntry entry; |
|
|
|
if (!testStartTagOrEmptyTag(parser, entry, "PARAMETER.REFARRAY")) |
|
return false; |
|
|
|
Boolean empty = entry.type == XmlEntry::EMPTY_TAG; |
|
|
|
// Get PARAMETER.NAME attribute: |
|
|
|
CIMName name = getCimNameAttribute( |
|
parser.getLine(), entry, "PARAMETER.REFARRAY"); |
|
|
|
// Get PARAMETER.REFERENCECLASS attribute: |
|
|
|
CIMName referenceClass = getReferenceClassAttribute( |
|
parser.getLine(), entry, "PARAMETER.REFARRAY"); |
|
|
|
// Get PARAMETER.ARRAYSIZE attribute: |
|
|
|
Uint32 arraySize = 0; |
|
getArraySizeAttribute( |
|
parser.getLine(), entry, "PARAMETER.REFARRAY", arraySize); |
|
|
|
// Create parameter: |
|
|
|
parameter = CIMParameter( |
|
name, CIMTYPE_REFERENCE, true, arraySize, referenceClass); |
|
|
|
if (!empty) |
|
{ |
|
getQualifierElements(parser, parameter); |
|
expectEndTag(parser, "PARAMETER.REFARRAY"); |
|
} |
|
|
|
return true; |
|
} |
|
|
|
//------------------------------------------------------------------------------ |
|
// |
// GetParameterElements() | // GetParameterElements() |
// | // |
//------------------------------------------------------------------------------ | //------------------------------------------------------------------------------ |
|
|
| |
while (XmlReader::getParameterElement(parser, parameter) || | while (XmlReader::getParameterElement(parser, parameter) || |
XmlReader::getParameterArrayElement(parser, parameter) || | XmlReader::getParameterArrayElement(parser, parameter) || |
XmlReader::getParameterReferenceElement(parser, parameter)) |
XmlReader::getParameterReferenceElement(parser, parameter) || |
|
XmlReader::getParameterReferenceArrayElement(parser, parameter)) |
{ | { |
try | try |
{ | { |
container.addParameter(parameter); | container.addParameter(parameter); |
} | } |
catch (AlreadyExists&) |
catch (AlreadyExistsException&) |
{ | { |
throw XmlSemanticError(parser.getLine(), "duplicate parameter"); |
MessageLoaderParms mlParms( |
|
"Common.XmlReader.DUPLICATE_PARAMETER", |
|
"duplicate parameter"); |
|
throw XmlSemanticError(parser.getLine(), mlParms); |
} | } |
} | } |
} | } |
|
|
| |
// Get NAME attribute: | // Get NAME attribute: |
| |
String name = getCimNameAttribute( |
CIMName name = getCimNameAttribute( |
parser.getLine(), entry, "QUALIFIER.DECLARATION"); | parser.getLine(), entry, "QUALIFIER.DECLARATION"); |
| |
// Get TYPE attribute: | // Get TYPE attribute: |
| |
CIMType type = getCimTypeAttribute( |
CIMType type; |
parser.getLine(), entry, "QUALIFIER.DECLARATION"); |
getCimTypeAttribute(parser.getLine(), entry, type, "QUALIFIER.DECLARATION"); |
| |
// Get ISARRAY attribute: | // Get ISARRAY attribute: |
| |
Boolean isArray = false; |
Boolean isArray = getCimBooleanAttribute( |
getIsArrayAttribute( |
parser.getLine(), entry, "QUALIFIER.DECLARATION", "ISARRAY", |
parser.getLine(), entry, "QUALIFIER.DECLARATION", isArray); |
false, false); |
| |
// Get ARRAYSIZE attribute: | // Get ARRAYSIZE attribute: |
| |
Uint32 arraySize = 0; | Uint32 arraySize = 0; |
Boolean gotArraySize = getArraySizeAttribute(parser.getLine(), |
getArraySizeAttribute(parser.getLine(), |
entry, "QUALIFIER.DECLARATION", arraySize); | entry, "QUALIFIER.DECLARATION", arraySize); |
| |
// Get flavor oriented attributes: | // Get flavor oriented attributes: |
| |
Uint32 flavor = getFlavor(entry,parser.getLine(), "QUALIFIER.DECLARATION"); |
CIMFlavor flavor = getFlavor (entry, parser.getLine (), |
|
"QUALIFIER.DECLARATION"); |
| |
// No need to look for interior elements if empty tag: | // No need to look for interior elements if empty tag: |
| |
Uint32 scope = CIMScope::NONE; |
CIMScope scope = CIMScope (); |
CIMValue value; | CIMValue value; |
|
Boolean gotValue = false; |
| |
if (!empty) | if (!empty) |
{ | { |
|
|
{ | { |
if (!isArray) | if (!isArray) |
{ | { |
throw XmlSemanticError(parser.getLine(), |
MessageLoaderParms mlParms( |
"VALUE.ARRAY element encountered without " |
"Common.XmlReader.ARRAY_WITHOUT_ISARRAY", |
"ISARRAY attribute"); |
"VALUE.ARRAY element encountered without ISARRAY " |
|
"attribute"); |
|
throw XmlSemanticError(parser.getLine(), mlParms); |
} | } |
| |
if (arraySize && arraySize != value.getArraySize()) | if (arraySize && arraySize != value.getArraySize()) |
{ | { |
throw XmlSemanticError(parser.getLine(), |
MessageLoaderParms mlParms( |
"VALUE.ARRAY size is not the same as " |
"Common.XmlReader.ARRAY_SIZE_NOT_SAME", |
"ARRAYSIZE attribute"); |
"VALUE.ARRAY size is not the same as ARRAYSIZE attribute"); |
|
throw XmlSemanticError(parser.getLine(), mlParms); |
} | } |
|
|
|
gotValue = true; |
} | } |
else if (getValueElement(parser, type, value)) | else if (getValueElement(parser, type, value)) |
{ | { |
if (isArray) | if (isArray) |
{ | { |
throw XmlSemanticError(parser.getLine(), |
MessageLoaderParms mlParms( |
|
"Common.XmlReader.ARRAY_ATTRIBUTE_DIFFERENT", |
"ISARRAY attribute used but VALUE element encountered"); | "ISARRAY attribute used but VALUE element encountered"); |
|
throw XmlSemanticError(parser.getLine(), mlParms); |
} | } |
|
|
|
gotValue = true; |
} | } |
| |
// Now get the closing tag: | // Now get the closing tag: |
|
|
expectEndTag(parser, "QUALIFIER.DECLARATION"); | expectEndTag(parser, "QUALIFIER.DECLARATION"); |
} | } |
| |
if (value.getType() == CIMType::NONE) |
if (!gotValue) |
{ | { |
if (isArray) | if (isArray) |
value.setNullValue(type, true, arraySize); | value.setNullValue(type, true, arraySize); |
|
|
| |
Boolean empty = entry.type == XmlEntry::EMPTY_TAG; | Boolean empty = entry.type == XmlEntry::EMPTY_TAG; |
| |
String name = getCimNameAttribute(parser.getLine(), entry, "PROPERTY"); |
CIMName name = getCimNameAttribute(parser.getLine(), entry, "METHOD"); |
| |
CIMType type = getCimTypeAttribute(parser.getLine(), entry, "PROPERTY"); |
CIMType type; |
|
getCimTypeAttribute(parser.getLine(), entry, type, "METHOD"); |
| |
String classOrigin = |
CIMName classOrigin = |
getClassOriginAttribute(parser.getLine(), entry, "PROPERTY"); |
getClassOriginAttribute(parser.getLine(), entry, "METHOD"); |
| |
Boolean propagated = getCimBooleanAttribute( | Boolean propagated = getCimBooleanAttribute( |
parser.getLine(), entry, "PROPERTY", "PROPAGATED", false, false); |
parser.getLine(), entry, "METHOD", "PROPAGATED", false, false); |
| |
method = CIMMethod(name, type, classOrigin, propagated); | method = CIMMethod(name, type, classOrigin, propagated); |
| |
if (!empty) | if (!empty) |
{ | { |
|
// ATTN-RK-P2-20020219: Decoding algorithm must not depend on the |
|
// ordering of qualifiers and parameters. |
getQualifierElements(parser, method); | getQualifierElements(parser, method); |
| |
GetParameterElements(parser, method); | GetParameterElements(parser, method); |
|
|
{ | { |
XmlEntry entry; | XmlEntry entry; |
| |
if (!testStartTag(parser, entry, "CLASS")) |
if (!testStartTagOrEmptyTag(parser, entry, "CLASS")) |
return false; | return false; |
| |
String name = getCimNameAttribute(parser.getLine(), entry, "CLASS"); |
CIMName name = getCimNameAttribute(parser.getLine(), entry, "CLASS"); |
| |
String superClass = getSuperClassAttribute(parser.getLine(), entry,"CLASS"); |
CIMName superClass = |
|
getSuperClassAttribute(parser.getLine(), entry,"CLASS"); |
| |
cimClass = CIMClass(name, superClass); | cimClass = CIMClass(name, superClass); |
| |
|
if (entry.type != XmlEntry::EMPTY_TAG) |
|
{ |
// Get QUALIFIER elements: | // Get QUALIFIER elements: |
| |
getQualifierElements(parser, cimClass); | getQualifierElements(parser, cimClass); |
|
|
// Get CLASS end tag: | // Get CLASS end tag: |
| |
expectEndTag(parser, "CLASS"); | expectEndTag(parser, "CLASS"); |
|
} |
| |
return true; | return true; |
} | } |
|
|
{ | { |
XmlEntry entry; | XmlEntry entry; |
| |
if (!testStartTag(parser, entry, "INSTANCE")) |
if (!testStartTagOrEmptyTag(parser, entry, "INSTANCE")) |
return false; | return false; |
| |
|
Boolean empty = entry.type == XmlEntry::EMPTY_TAG; |
|
|
String className = getClassNameAttribute( | String className = getClassNameAttribute( |
parser.getLine(), entry, "INSTANCE"); | parser.getLine(), entry, "INSTANCE"); |
| |
cimInstance = CIMInstance(className); |
cimInstance = CIMInstance(className); |
|
|
|
if (!empty) |
|
{ |
|
// Get QUALIFIER elements: |
|
getQualifierElements(parser, cimInstance); |
|
|
|
// Get PROPERTY elements: |
|
GetPropertyElements(parser, cimInstance); |
|
|
|
// Get INSTANCE end tag: |
|
expectEndTag(parser, "INSTANCE"); |
|
} |
|
|
|
return true; |
|
} |
|
|
|
//------------------------------------------------------------------------------ |
|
// getNamedInstanceElement() |
|
// |
|
// <!ELEMENT VALUE.NAMEDINSTANCE (INSTANCENAME,INSTANCE)> |
|
// |
|
//------------------------------------------------------------------------------ |
|
|
|
Boolean XmlReader::getNamedInstanceElement( |
|
XmlParser& parser, |
|
CIMInstance& namedInstance) |
|
{ |
|
XmlEntry entry; |
|
|
|
if (!testStartTag(parser, entry, "VALUE.NAMEDINSTANCE")) |
|
return false; |
|
|
|
CIMObjectPath instanceName; |
|
|
|
// Get INSTANCENAME elements: |
|
|
|
if (!getInstanceNameElement(parser, instanceName)) |
|
{ |
|
MessageLoaderParms mlParms( |
|
"Common.XmlReader.EXPECTED_INSTANCENAME_ELEMENT", |
|
"expected INSTANCENAME element"); |
|
throw XmlValidationError(parser.getLine(), mlParms); |
|
} |
|
|
|
// Get INSTANCE elements: |
|
|
|
if (!getInstanceElement(parser, namedInstance)) |
|
{ |
|
MessageLoaderParms mlParms( |
|
"Common.XmlReader.EXPECTED_INSTANCE_ELEMENT", |
|
"expected INSTANCE element"); |
|
throw XmlValidationError(parser.getLine(), mlParms); |
|
} |
|
|
|
// Get VALUE.NAMEDINSTANCE end tag: |
|
|
|
expectEndTag(parser, "VALUE.NAMEDINSTANCE"); |
|
|
|
namedInstance.setPath (instanceName); |
|
|
|
return true; |
|
} |
|
|
|
|
|
//EXP_PULL_BEGIN |
|
//------------------------------------------------------------------------------ |
|
// getInstanceWithPathElement() |
|
// |
|
// <!ELEMENT VALUE.NAMEDINSTANCE (INSTANCENAME,INSTANCE)> |
|
// |
|
//------------------------------------------------------------------------------ |
|
|
|
Boolean XmlReader::getInstanceWithPathElement( |
|
XmlParser& parser, |
|
CIMInstance& namedInstance) |
|
{ |
|
XmlEntry entry; |
|
if (!testStartTag(parser, entry, "VALUE.INSTANCEWITHPATH")) |
|
return false; |
|
|
|
CIMObjectPath instanceName; |
|
|
|
// Get INSTANCENAME elements: |
|
if (!getInstancePathElement(parser, instanceName)) |
|
{ |
|
MessageLoaderParms mlParms( |
|
"Common.XmlReader.EXPECTED_INSTANCEPATH_ELEMENT", |
|
"expected INSTANCEPATH element"); |
|
throw XmlValidationError(parser.getLine(), mlParms); |
|
} |
|
|
|
// Get INSTANCE elements: |
|
|
|
if (!getInstanceElement(parser, namedInstance)) |
|
{ |
|
MessageLoaderParms mlParms( |
|
"Common.XmlReader.EXPECTED_INSTANCE_ELEMENT", |
|
"expected INSTANCE element"); |
|
throw XmlValidationError(parser.getLine(), mlParms); |
|
} |
|
// Get VALUE.NAMEDINSTANCE end tag: |
|
|
|
expectEndTag(parser, "VALUE.INSTANCEWITHPATH"); |
|
|
|
namedInstance.setPath (instanceName); |
|
|
|
return true; |
|
} |
|
|
|
//EXP_PULL_END |
|
|
|
//------------------------------------------------------------------------------ |
|
// |
|
// getObject() |
|
// |
|
//------------------------------------------------------------------------------ |
|
|
|
void XmlReader::getObject(XmlParser& parser, CIMClass& x) |
|
{ |
|
if (!getClassElement(parser, x)) |
|
{ |
|
MessageLoaderParms mlParms( |
|
"Common.XmlReader.EXPECTED_CLASS_ELEMENT", |
|
"expected CLASS element"); |
|
throw XmlValidationError(parser.getLine(), mlParms); |
|
} |
|
} |
|
|
|
//------------------------------------------------------------------------------ |
|
// |
|
// getObject() |
|
// |
|
//------------------------------------------------------------------------------ |
|
|
|
void XmlReader::getObject(XmlParser& parser, CIMInstance& x) |
|
{ |
|
if (!getInstanceElement(parser, x)) |
|
{ |
|
MessageLoaderParms mlParms( |
|
"Common.XmlReader.EXPECTED_INSTANCE_ELEMENT", |
|
"expected INSTANCE element"); |
|
throw XmlValidationError(parser.getLine(), mlParms); |
|
} |
|
} |
|
|
|
//------------------------------------------------------------------------------ |
|
// |
|
// getObject() |
|
// |
|
//------------------------------------------------------------------------------ |
|
|
|
void XmlReader::getObject(XmlParser& parser, CIMQualifierDecl& x) |
|
{ |
|
if (!getQualifierDeclElement(parser, x)) |
|
{ |
|
MessageLoaderParms mlParms( |
|
"Common.XmlReader.EXPECTED_QUALIFIER_DECLARATION_ELEMENT", |
|
"expected QUALIFIER.DECLARATION element"); |
|
throw XmlValidationError(parser.getLine(), mlParms); |
|
} |
|
} |
|
|
|
//------------------------------------------------------------------------------ |
|
// |
|
// getMessageStartTag() |
|
// |
|
//------------------------------------------------------------------------------ |
|
|
|
Boolean XmlReader::getMessageStartTag( |
|
XmlParser& parser, |
|
String& id, |
|
String& protocolVersion) |
|
{ |
|
XmlEntry entry; |
|
|
|
if (!testStartTag(parser, entry, "MESSAGE")) |
|
return false; |
|
|
|
// Get MESSAGE.ID: |
|
|
|
if (!entry.getAttributeValue("ID", id)) |
|
{ |
|
MessageLoaderParms mlParms( |
|
"Common.XmlReader.INVALID_MISSING_MESSAGE_ID_ATTRIBUTE", |
|
"Invalid or missing MESSAGE.ID attribute"); |
|
throw XmlValidationError(parser.getLine(), mlParms); |
|
} |
|
|
|
|
|
// Get MESSAGE.PROTOCOLVERSION: |
|
|
|
if (!entry.getAttributeValue("PROTOCOLVERSION", protocolVersion)) |
|
{ |
|
MessageLoaderParms mlParms( |
|
"Common.XmlReader.INVALID_MISSING_PROTOCOLVERSION_ATTRIBUTE", |
|
"Invalid or missing MESSAGE.PROTOCOLVERSION attribute"); |
|
throw XmlValidationError(parser.getLine(), mlParms); |
|
} |
|
|
|
return true; |
|
} |
|
|
|
//------------------------------------------------------------------------------ |
|
// |
|
// getIMethodCallStartTag() |
|
// |
|
//------------------------------------------------------------------------------ |
|
|
|
Boolean XmlReader::getIMethodCallStartTag( |
|
XmlParser& parser, |
|
const char*& name) |
|
{ |
|
XmlEntry entry; |
|
|
|
if (!testStartTag(parser, entry, "IMETHODCALL")) |
|
return false; |
|
|
|
// Get IMETHODCALL.NAME attribute: |
|
|
|
|
|
if (!entry.getAttributeValue("NAME", name)) |
|
{ |
|
MessageLoaderParms mlParms( |
|
"Common.XmlReader.MISSING_IMETHODCALL_ATTRIBUTE", |
|
"Missing IMETHODCALL.NAME attribute"); |
|
throw XmlValidationError(parser.getLine(), mlParms); |
|
} |
|
|
|
|
|
return true; |
|
} |
|
|
|
//------------------------------------------------------------------------------ |
|
// |
|
// getIMethodResponseStartTag() |
|
// |
|
//------------------------------------------------------------------------------ |
|
|
|
Boolean XmlReader::getIMethodResponseStartTag( |
|
XmlParser& parser, |
|
const char*& name, |
|
Boolean& isEmptyTag) |
|
{ |
|
XmlEntry entry; |
|
|
|
if (!testStartTagOrEmptyTag(parser, entry, "IMETHODRESPONSE")) |
|
return false; |
|
|
|
isEmptyTag = (entry.type == XmlEntry::EMPTY_TAG); |
|
|
|
// Get IMETHODRESPONSE.NAME attribute: |
|
|
|
if (!entry.getAttributeValue("NAME", name)) |
|
{ |
|
MessageLoaderParms mlParms( |
|
"Common.XmlReader.MISSING_IMETHODRESPONSE_ATTRIBUTE", |
|
"Missing IMETHODRESPONSE.NAME attribute"); |
|
throw XmlValidationError(parser.getLine(), mlParms); |
|
} |
|
|
|
|
|
return true; |
|
} |
|
|
|
//------------------------------------------------------------------------------ |
|
// |
|
// getIParamValueTag() |
|
// |
|
//------------------------------------------------------------------------------ |
|
|
|
Boolean XmlReader::getIParamValueTag( |
|
XmlParser& parser, |
|
const char*& name, |
|
Boolean& isEmptyTag) |
|
{ |
|
XmlEntry entry; |
|
|
|
if (!testStartTagOrEmptyTag(parser, entry, "IPARAMVALUE")) |
|
return false; |
|
|
|
isEmptyTag = (entry.type == XmlEntry::EMPTY_TAG); |
|
|
|
// Get IPARAMVALUE.NAME attribute: |
|
|
|
if (!entry.getAttributeValue("NAME", name)) |
|
{ |
|
MessageLoaderParms mlParms( |
|
"Common.XmlReader.MISSING_IPARAMVALUE_ATTRIBUTE", |
|
"Missing IPARAMVALUE.NAME attribute"); |
|
throw XmlValidationError(parser.getLine(), mlParms); |
|
} |
|
|
|
return true; |
|
} |
|
|
|
//EXP_PULL_BEGIN |
|
//------------------------------------------------------------------------------ |
|
// |
|
// getIParamValueTag() |
|
// |
|
//------------------------------------------------------------------------------ |
|
|
|
Boolean XmlReader::getParamValueTag( |
|
XmlParser& parser, |
|
const char*& name, |
|
Boolean& isEmptyTag) |
|
{ |
|
XmlEntry entry; |
|
|
|
if (!testStartTagOrEmptyTag(parser, entry, "PARAMVALUE")) |
|
{ |
|
|
|
return false; |
|
} |
|
|
|
isEmptyTag = (entry.type == XmlEntry::EMPTY_TAG); |
|
|
|
// Get PARAMVALUE.NAME attribute: |
|
|
|
if (!entry.getAttributeValue("NAME", name)) |
|
{ |
|
MessageLoaderParms mlParms( |
|
"Common.XmlReader.MISSING_PARAMVALUE_ATTRIBUTE", |
|
"Missing PARAMVALUE.NAME attribute"); |
|
throw XmlValidationError(parser.getLine(), mlParms); |
|
} |
|
return true; |
|
} |
|
//------------------------------------------------------------------------------ |
|
// |
|
// getIReturnValueTag() |
|
// |
|
//------------------------------------------------------------------------------ |
|
|
|
Boolean XmlReader::getIReturnValueTag( |
|
XmlParser& parser, |
|
const char*& name, |
|
Boolean& isEmptyTag) |
|
{ |
|
XmlEntry entry; |
|
if (!testStartTagOrEmptyTag(parser, entry, "IRETURNVALUE")) |
|
return false; |
|
//entry.print(); |
|
isEmptyTag = (entry.type == XmlEntry::EMPTY_TAG); |
|
|
|
if (!entry.getAttributeValue("NAME", name)) |
|
{ |
|
MessageLoaderParms mlParms( |
|
"Common.XmlReader.MISSING_IRETURNVALUE_ATTRIBUTE", |
|
"Missing IRETURNVALUE.NAME attribute"); |
|
throw XmlValidationError(parser.getLine(), mlParms); |
|
} |
|
return true; |
|
} |
|
|
|
//EXP_PULL_END |
|
//------------------------------------------------------------------------------ |
|
// |
|
// rejectNullIParamValue() |
|
// |
|
//------------------------------------------------------------------------------ |
|
|
|
void XmlReader::rejectNullIParamValue( |
|
XmlParser& parser, |
|
Boolean isEmptyTag, |
|
const char* paramName) |
|
{ |
|
if (isEmptyTag) |
|
{ |
|
MessageLoaderParms mlParms("Common.XmlReader.INVALID_NULL_IPARAMVALUE", |
|
"A null value is not valid for IPARAMVALUE \"$0\".", |
|
paramName); |
|
throw XmlValidationError(parser.getLine(), mlParms); |
|
} |
|
} |
|
|
|
// EXP_PULL_BEGIN |
|
//------------------------------------------------------------------------------ |
|
// |
|
// rejectNullIReturnParamValue() |
|
// |
|
//------------------------------------------------------------------------------ |
|
|
|
void XmlReader::rejectNullIReturnValue( |
|
XmlParser& parser, |
|
Boolean isEmptyTag, |
|
const char* paramName) |
|
{ |
|
if (isEmptyTag) |
|
{ |
|
MessageLoaderParms mlParms("Common.XmlReader.INVALID_NULL_IRETURNVALUE", |
|
"A null value is not valid for IRETURNVALUE \"$0\".", |
|
paramName); |
|
throw XmlValidationError(parser.getLine(), mlParms); |
|
} |
|
} |
|
|
|
void XmlReader::rejectNullParamValue( |
|
XmlParser& parser, |
|
Boolean isEmptyTag, |
|
const char* paramName) |
|
{ |
|
if (isEmptyTag) |
|
{ |
|
MessageLoaderParms mlParms("Common.XmlReader.INVALID_NULL_PARAMVALUE", |
|
"A null value is not valid for PARAMVALUE \"$0\".", |
|
paramName); |
|
throw XmlValidationError(parser.getLine(), mlParms); |
|
} |
|
} |
|
// EXP_PULL_END |
|
//------------------------------------------------------------------------------ |
|
// |
|
// getBooleanValueElement() |
|
// |
|
// Get an elements like: "<VALUE>FALSE</VALUE>" |
|
// |
|
//------------------------------------------------------------------------------ |
|
|
|
Boolean XmlReader::getBooleanValueElement( |
|
XmlParser& parser, |
|
Boolean& result, |
|
Boolean required) |
|
{ |
|
XmlEntry entry; |
|
|
|
if (!testStartTag(parser, entry, "VALUE")) |
|
{ |
|
if (required) |
|
{ |
|
MessageLoaderParms mlParms( |
|
"Common.XmlReader.EXPECTED_VALUE_ELEMENT", |
|
"Expected VALUE element"); |
|
throw XmlValidationError(parser.getLine(), mlParms); |
|
} |
|
return false; |
|
} |
|
|
|
expectContentOrCData(parser, entry); |
|
|
|
if (System::strcasecmp(entry.text, "TRUE") == 0) |
|
result = true; |
|
else if (System::strcasecmp(entry.text, "FALSE") == 0) |
|
result = false; |
|
else |
|
{ |
|
MessageLoaderParms mlParms( |
|
"Common.XmlReader.INVALID_VALUE_FOR_VALUE_ELEMENT", |
|
"Invalid value for VALUE element: must be \"TRUE\" or \"FALSE\""); |
|
throw XmlSemanticError(parser.getLine(), mlParms); |
|
} |
|
|
|
expectEndTag(parser, "VALUE"); |
|
|
|
return true; |
|
} |
|
|
|
//------------------------------------------------------------------------------ |
|
// |
|
// DMTF CR Pending |
|
// |
|
// <!ELEMENT ERROR (INSTANCE*)> |
|
// <!ATTLIST ERROR |
|
// CODE CDATA #REQUIRED |
|
// DESCRIPTION CDATA #IMPLIED> |
|
// |
|
//------------------------------------------------------------------------------ |
|
|
|
Boolean XmlReader::getErrorElement( |
|
XmlParser& parser, |
|
CIMException& cimException, |
|
Boolean required) |
|
{ |
|
XmlEntry entry; |
|
|
|
if (!testStartTagOrEmptyTag(parser, entry, "ERROR")) |
|
{ |
|
if (required) |
|
{ |
|
MessageLoaderParms mlParms( |
|
"Common.XmlReader.EXPECTED_ERROR_ELEMENT", |
|
"Expected ERROR element"); |
|
throw XmlValidationError(parser.getLine(), mlParms); |
|
} |
|
return false; |
|
} |
|
|
|
Boolean empty = entry.type == XmlEntry::EMPTY_TAG; |
|
|
|
// Get ERROR.CODE |
|
|
|
Uint32 tmpCode; |
|
|
|
if (!entry.getAttributeValue("CODE", tmpCode)) |
|
{ |
|
MessageLoaderParms mlParms( |
|
"Common.XmlReader.MISSING_ERROR_CODE_ATTRIBUTE", |
|
"missing ERROR.CODE attribute"); |
|
throw XmlValidationError(parser.getLine(), mlParms); |
|
} |
|
|
|
// Get ERROR.DESCRIPTION: |
|
|
|
String tmpDescription; |
|
|
|
entry.getAttributeValue("DESCRIPTION", tmpDescription); |
|
|
|
cimException = |
|
PEGASUS_CIM_EXCEPTION(CIMStatusCode(tmpCode), tmpDescription); |
|
|
|
if (!empty) |
|
{ |
|
CIMInstance instance; |
|
|
|
while (getInstanceElement(parser, instance)) |
|
{ |
|
cimException.addError(instance); |
|
} |
|
|
|
expectEndTag(parser, "ERROR"); |
|
} |
|
|
|
return true; |
|
} |
|
|
|
//------------------------------------------------------------------------------ |
|
// getValueObjectElement() |
|
// |
|
// <!ELEMENT VALUE.OBJECT (CLASS|INSTANCE)> |
|
// |
|
//------------------------------------------------------------------------------ |
|
|
|
Boolean XmlReader::getValueObjectElement( |
|
XmlParser& parser, |
|
CIMObject& object) |
|
{ |
|
XmlEntry entry; |
|
|
|
if (!testStartTag(parser, entry, "VALUE.OBJECT")) |
|
return false; |
|
|
|
CIMInstance cimInstance; |
|
CIMClass cimClass; |
|
|
|
if (XmlReader::getInstanceElement(parser, cimInstance)) |
|
{ |
|
object = CIMObject(cimInstance); |
|
} |
|
else if (XmlReader::getClassElement(parser, cimClass)) |
|
{ |
|
object = CIMObject(cimClass); |
|
} |
|
else |
|
{ |
|
MessageLoaderParms mlParms( |
|
"Common.XmlReader.EXPECTED_INSTANCE_OR_CLASS_ELEMENT", |
|
"Expected INSTANCE or CLASS element"); |
|
throw XmlValidationError(parser.getLine(), mlParms); |
|
} |
|
|
|
expectEndTag(parser, "VALUE.OBJECT"); |
|
|
|
return true; |
|
} |
|
|
|
//------------------------------------------------------------------------------ |
|
// getValueObjectWithPathElement() |
|
// |
|
// <!ELEMENT VALUE.OBJECTWITHPATH ((CLASSPATH,CLASS)|(INSTANCEPATH,INSTANCE))> |
|
// |
|
//------------------------------------------------------------------------------ |
|
|
|
Boolean XmlReader::getValueObjectWithPathElement( |
|
XmlParser& parser, |
|
CIMObject& objectWithPath) |
|
{ |
|
XmlEntry entry; |
|
|
|
if (!testStartTag(parser, entry, "VALUE.OBJECTWITHPATH")) |
|
return false; |
|
|
|
CIMObjectPath reference; |
|
Boolean isInstance = false; |
|
|
|
if (XmlReader::getInstancePathElement(parser, reference)) |
|
isInstance = true; |
|
else if (!XmlReader::getClassPathElement(parser, reference)) |
|
{ |
|
MessageLoaderParms mlParms( |
|
"Common.XmlReader.EXPECTED_INSTANCEPATH_OR_CLASSPATH_ELEMENT", |
|
"Expected INSTANCEPATH or CLASSPATH element"); |
|
throw XmlValidationError(parser.getLine(), mlParms); |
|
} |
|
|
|
if (isInstance) |
|
{ |
|
CIMInstance cimInstance; |
|
|
|
if (!XmlReader::getInstanceElement(parser, cimInstance)) |
|
{ |
|
MessageLoaderParms mlParms( |
|
"Common.XmlReader.EXPECTED_INSTANCE_ELEMENT", |
|
"Expected INSTANCE element"); |
|
throw XmlValidationError(parser.getLine(), mlParms); |
|
} |
|
objectWithPath = CIMObject (cimInstance); |
|
objectWithPath.setPath (reference); |
|
} |
|
else |
|
{ |
|
CIMClass cimClass; |
|
|
|
if (!XmlReader::getClassElement(parser, cimClass)) |
|
{ |
|
MessageLoaderParms mlParms( |
|
"Common.XmlReader.EXPECTED_CLASS_ELEMENT", |
|
"Expected CLASS element"); |
|
throw XmlValidationError(parser.getLine(), mlParms); |
|
} |
|
objectWithPath = CIMObject (cimClass); |
|
objectWithPath.setPath (reference); |
|
} |
|
|
|
expectEndTag(parser, "VALUE.OBJECTWITHPATH"); |
|
|
|
return true; |
|
} |
|
|
|
//------------------------------------------------------------------------------ |
|
// getValueObjectWithLocalPathElement() |
|
// |
|
// <!ELEMENT VALUE.OBJECTWITHLOCALPATH |
|
// ((LOCALCLASSPATH,CLASS)|(LOCALINSTANCEPATH,INSTANCE))> |
|
// |
|
//------------------------------------------------------------------------------ |
|
|
|
Boolean XmlReader::getValueObjectWithLocalPathElement( |
|
XmlParser& parser, |
|
CIMObject& objectWithPath) |
|
{ |
|
XmlEntry entry; |
|
|
|
if (!testStartTag(parser, entry, "VALUE.OBJECTWITHLOCALPATH")) |
|
return false; |
|
|
|
CIMObjectPath reference; |
|
Boolean isInstance = false; |
|
|
|
if (XmlReader::getLocalInstancePathElement(parser, reference)) |
|
isInstance = true; |
|
else if (!XmlReader::getLocalClassPathElement(parser, reference)) |
|
{ |
|
MessageLoaderParms mlParms( |
|
"Common.XmlConstants.MISSING_ELEMENT_LOCALPATH", |
|
MISSING_ELEMENT_LOCALPATH); |
|
throw XmlValidationError(parser.getLine(), mlParms); |
|
} |
|
|
|
if (isInstance) |
|
{ |
|
CIMInstance cimInstance; |
|
|
|
if (!XmlReader::getInstanceElement(parser, cimInstance)) |
|
{ |
|
MessageLoaderParms mlParms( |
|
"Common.XmlReader.EXPECTED_INSTANCE_ELEMENT", |
|
"Expected INSTANCE element"); |
|
throw XmlValidationError(parser.getLine(), mlParms); |
|
} |
|
objectWithPath = CIMObject (cimInstance); |
|
objectWithPath.setPath (reference); |
|
} |
|
else |
|
{ |
|
CIMClass cimClass; |
| |
// Get QUALIFIER elements: |
if (!XmlReader::getClassElement(parser, cimClass)) |
|
{ |
|
MessageLoaderParms mlParms( |
|
"Common.XmlReader.EXPECTED_CLASS_ELEMENT", |
|
"Expected CLASS element"); |
|
throw XmlValidationError(parser.getLine(), mlParms); |
|
} |
|
objectWithPath = CIMObject (cimClass); |
|
objectWithPath.setPath (reference); |
|
} |
| |
getQualifierElements(parser, cimInstance); |
expectEndTag(parser, "VALUE.OBJECTWITHLOCALPATH"); |
| |
// Get PROPERTY elements: |
return true; |
|
} |
| |
GetPropertyElements(parser, cimInstance); |
//------------------------------------------------------------------------------ |
|
// getObjectArray() |
|
// |
|
// <object> |
|
// (VALUE.OBJECT|VALUE.OBJECTWITHLOCALPATH|VALUE.OBJECTWITHPATH) |
|
// |
|
//------------------------------------------------------------------------------ |
| |
// Get INSTANCE end tag: |
void XmlReader::getObjectArray( |
|
XmlParser& parser, |
|
Array<CIMObject>& objectArray) |
|
{ |
|
CIMObject object; |
|
CIMObject objectWithPath; |
| |
expectEndTag(parser, "INSTANCE"); |
objectArray.clear(); |
| |
return true; |
if (getValueObjectElement(parser, object)) |
|
{ |
|
objectArray.append(object); |
|
while (getValueObjectElement(parser, object)) |
|
objectArray.append(object); |
|
} |
|
else if (getValueObjectWithPathElement(parser, objectWithPath)) |
|
{ |
|
objectArray.append(objectWithPath); |
|
while (getValueObjectWithPathElement(parser, objectWithPath)) |
|
objectArray.append(objectWithPath); |
|
} |
|
else if (getValueObjectWithLocalPathElement(parser, objectWithPath)) |
|
{ |
|
objectArray.append(objectWithPath); |
|
while (getValueObjectWithLocalPathElement(parser, objectWithPath)) |
|
objectArray.append(objectWithPath); |
|
} |
} | } |
| |
//------------------------------------------------------------------------------ | //------------------------------------------------------------------------------ |
// | // |
// getObject() |
// <objectName>: (CLASSNAME|INSTANCENAME) |
// | // |
//------------------------------------------------------------------------------ | //------------------------------------------------------------------------------ |
| |
void XmlReader::getObject(XmlParser& parser, CIMClass& x) |
// Returns true if ClassNameElement or false if InstanceNameElement |
|
// Parse errors always throw exception |
|
Boolean XmlReader::getObjectNameElement( |
|
XmlParser& parser, |
|
CIMObjectPath& objectName) |
{ | { |
if (!getClassElement(parser, x)) |
CIMName className; |
|
|
|
if (getClassNameElement(parser, className, false)) |
{ | { |
throw XmlValidationError(parser.getLine(), |
objectName.set(String(), CIMNamespaceName(), className); |
"expected CLASS element"); |
|
|
// Return flag indicating this is ClassNameElement |
|
return true; |
|
} |
|
|
|
if (!getInstanceNameElement(parser, objectName)) |
|
{ |
|
MessageLoaderParms mlParms( |
|
"Common.XmlReader.EXPECTED_CLASSNAME_OR_INSTANCENAME_ELEMENT", |
|
"Expected CLASSNAME or INSTANCENAME element"); |
|
throw XmlValidationError(parser.getLine(), mlParms); |
} | } |
|
|
|
// Return flag indicating this is InstanceNameElement |
|
return false; |
} | } |
| |
//------------------------------------------------------------------------------ | //------------------------------------------------------------------------------ |
// | // |
// getObject() |
// <!ELEMENT OBJECTPATH (INSTANCEPATH|CLASSPATH)> |
// | // |
//------------------------------------------------------------------------------ | //------------------------------------------------------------------------------ |
| |
void XmlReader::getObject(XmlParser& parser, CIMInstance& x) |
Boolean XmlReader::getObjectPathElement( |
|
XmlParser& parser, |
|
CIMObjectPath& objectPath) |
{ | { |
if (!getInstanceElement(parser, x)) |
XmlEntry entry; |
|
|
|
if (!testStartTag(parser, entry, "OBJECTPATH")) |
|
return false; |
|
|
|
if (!getClassPathElement(parser, objectPath) && |
|
!getInstancePathElement(parser, objectPath)) |
{ | { |
throw XmlValidationError(parser.getLine(), |
MessageLoaderParms mlParms( |
"expected INSTANCE element"); |
"Common.XmlReader.EXPECTED_INSTANCEPATH_OR_CLASSPATH_ELEMENT", |
|
"expected INSTANCEPATH or CLASSPATH element"); |
|
throw XmlValidationError(parser.getLine(), mlParms); |
} | } |
|
|
|
expectEndTag(parser, "OBJECTPATH"); |
|
return true; |
} | } |
| |
//------------------------------------------------------------------------------ | //------------------------------------------------------------------------------ |
// | // |
// getObject() |
// getEMethodCallStartTag() |
// | // |
//------------------------------------------------------------------------------ | //------------------------------------------------------------------------------ |
| |
void XmlReader::getObject(XmlParser& parser, CIMQualifierDecl& x) |
Boolean XmlReader::getEMethodCallStartTag( |
|
XmlParser& parser, |
|
const char*& name) |
{ | { |
if (!getQualifierDeclElement(parser, x)) |
XmlEntry entry; |
|
|
|
if (!testStartTag(parser, entry, "EXPMETHODCALL")) |
|
return false; |
|
|
|
// Get EXPMETHODCALL.NAME attribute: |
|
|
|
|
|
if (!entry.getAttributeValue("NAME", name)) |
{ | { |
throw XmlValidationError(parser.getLine(), |
MessageLoaderParms mlParms( |
"expected QUALIFIER.DECLARATION element"); |
"Common.XmlReader.MISSING_EXPMETHODCALL_ATTRIBUTE", |
|
"Missing EXPMETHODCALL.NAME attribute"); |
|
throw XmlValidationError(parser.getLine(), mlParms); |
} | } |
|
|
|
return true; |
} | } |
| |
//------------------------------------------------------------------------------ | //------------------------------------------------------------------------------ |
// | // |
// getMessageStartTag() |
// getEMethodResponseStartTag() |
// | // |
//------------------------------------------------------------------------------ | //------------------------------------------------------------------------------ |
| |
Boolean XmlReader::getMessageStartTag( |
Boolean XmlReader::getEMethodResponseStartTag( |
XmlParser& parser, | XmlParser& parser, |
String& id, |
const char*& name, |
const char*& protocolVersion) |
Boolean& isEmptyTag) |
{ | { |
XmlEntry entry; | XmlEntry entry; |
| |
if (!testStartTag(parser, entry, "MESSAGE")) |
if (!testStartTagOrEmptyTag(parser, entry, "EXPMETHODRESPONSE")) |
return false; | return false; |
| |
// Get MESSAGE.ID: |
isEmptyTag = (entry.type == XmlEntry::EMPTY_TAG); |
| |
if (!entry.getAttributeValue("ID", id)) |
// Get EXPMETHODRESPONSE.NAME attribute: |
throw XmlValidationError(parser.getLine(), |
|
"Bad or missing MESSAGE.ID attribute"); |
|
| |
// Get MESSAGE.PROTOCOLVERSION: |
|
| |
if (!entry.getAttributeValue("PROTOCOLVERSION", protocolVersion)) |
if (!entry.getAttributeValue("NAME", name)) |
throw XmlValidationError(parser.getLine(), |
{ |
"Bad or missing MESSAGE.PROTOCOLVERSION attribute"); |
MessageLoaderParms mlParms( |
|
"Common.XmlReader.MISSING_EXPMETHODRESPONSE_ATTRIBUTE", |
|
"Missing EXPMETHODRESPONSE.NAME attribute"); |
|
throw XmlValidationError(parser.getLine(), mlParms); |
|
} |
| |
return true; | return true; |
} | } |
| |
//------------------------------------------------------------------------------ | //------------------------------------------------------------------------------ |
// | // |
// getIMethodCallStartTag() |
// getEParamValueTag() |
// | // |
//------------------------------------------------------------------------------ | //------------------------------------------------------------------------------ |
| |
Boolean XmlReader::getIMethodCallStartTag( |
Boolean XmlReader::getEParamValueTag( |
XmlParser& parser, | XmlParser& parser, |
const char*& name) | const char*& name) |
{ | { |
XmlEntry entry; | XmlEntry entry; |
| |
if (!testStartTag(parser, entry, "IMETHODCALL")) |
if (!testStartTag(parser, entry, "EXPPARAMVALUE")) |
return false; | return false; |
| |
// Get IMETHODCALL.NAME attribute: |
// Get EXPPARAMVALUE.NAME attribute: |
|
|
| |
if (!entry.getAttributeValue("NAME", name)) | if (!entry.getAttributeValue("NAME", name)) |
throw XmlValidationError(parser.getLine(), |
{ |
"Missing IMETHODCALL.NAME attribute"); |
MessageLoaderParms mlParms( |
|
"Common.XmlReader.MISSING_EXPPARAMVALUE_ATTRIBUTE", |
|
"Missing EXPPARAMVALUE.NAME attribute"); |
|
throw XmlValidationError(parser.getLine(), mlParms); |
|
} |
|
|
|
|
| |
return true; | return true; |
} | } |
| |
//------------------------------------------------------------------------------ | //------------------------------------------------------------------------------ |
// | // |
// getIMethodResponseStartTag() |
// getMethodCallStartTag() |
// | // |
//------------------------------------------------------------------------------ | //------------------------------------------------------------------------------ |
| |
Boolean XmlReader::getIMethodResponseStartTag( |
Boolean XmlReader::getMethodCallStartTag( |
XmlParser& parser, | XmlParser& parser, |
const char*& name) | const char*& name) |
{ | { |
XmlEntry entry; | XmlEntry entry; |
| |
if (!testStartTag(parser, entry, "IMETHODRESPONSE")) |
if (!testStartTag(parser, entry, "METHODCALL")) |
return false; | return false; |
| |
// Get IMETHODRESPONSE.NAME attribute: |
// Get METHODCALL.NAME attribute: |
|
|
| |
if (!entry.getAttributeValue("NAME", name)) | if (!entry.getAttributeValue("NAME", name)) |
throw XmlValidationError(parser.getLine(), |
{ |
"Missing IMETHODRESPONSE.NAME attribute"); |
MessageLoaderParms mlParms( |
|
"Common.XmlReader.MISSING_METHODCALL_ATTRIBUTE", |
|
"Missing METHODCALL.NAME attribute"); |
|
throw XmlValidationError(parser.getLine(), mlParms); |
|
} |
|
|
| |
return true; | return true; |
} | } |
| |
//------------------------------------------------------------------------------ | //------------------------------------------------------------------------------ |
// | // |
// getIParamValueTag() |
// getMethodResponseStartTag() |
// | // |
//------------------------------------------------------------------------------ | //------------------------------------------------------------------------------ |
| |
Boolean XmlReader::getIParamValueTag( |
Boolean XmlReader::getMethodResponseStartTag( |
XmlParser& parser, | XmlParser& parser, |
const char*& name) |
const char*& name, |
|
Boolean& isEmptyTag) |
{ | { |
XmlEntry entry; | XmlEntry entry; |
| |
if (!testStartTag(parser, entry, "IPARAMVALUE")) |
if (!testStartTagOrEmptyTag(parser, entry, "METHODRESPONSE")) |
return false; | return false; |
| |
// Get IPARAMVALUE.NAME attribute: |
isEmptyTag = (entry.type == XmlEntry::EMPTY_TAG); |
|
|
|
// Get METHODRESPONSE.NAME attribute: |
|
|
| |
if (!entry.getAttributeValue("NAME", name)) | if (!entry.getAttributeValue("NAME", name)) |
throw XmlValidationError(parser.getLine(), |
{ |
"Missing IPARAMVALUE.NAME attribute"); |
MessageLoaderParms mlParms( |
|
"Common.XmlReader.MISSING_METHODRESPONSE_ATTRIBUTE", |
|
"Missing METHODRESPONSE.NAME attribute"); |
|
throw XmlValidationError(parser.getLine(), mlParms); |
|
} |
| |
return true; | return true; |
} | } |
| |
//------------------------------------------------------------------------------ | //------------------------------------------------------------------------------ |
// | // |
// getBooleanValueElement() |
// getParamValueElement() |
// | // |
// Get an elements like: "<VALUE>FALSE</VALUE>" |
// <!ELEMENT PARAMVALUE (VALUE|VALUE.REFERENCE|VALUE.ARRAY|VALUE.REFARRAY)?> |
|
// <!ATTLIST PARAMVALUE |
|
// %CIMName; |
|
// %EmbeddedObject; #IMPLIED |
|
// %ParamType;> |
// | // |
//------------------------------------------------------------------------------ | //------------------------------------------------------------------------------ |
| |
Boolean XmlReader::getBooleanValueElement( |
Boolean XmlReader::getParamValueElement( |
XmlParser& parser, | XmlParser& parser, |
Boolean& result, |
CIMParamValue& paramValue) |
Boolean required) |
|
{ | { |
XmlEntry entry; | XmlEntry entry; |
|
const char* name; |
|
CIMType type=CIMTYPE_BOOLEAN; |
|
CIMValue value; |
| |
if (!testStartTag(parser, entry, "VALUE")) |
if (!testStartTagOrEmptyTag(parser, entry, "PARAMVALUE")) |
{ |
|
if (required) |
|
{ |
|
throw XmlValidationError(parser.getLine(), |
|
"Expected VALUE element"); |
|
} |
|
return false; | return false; |
|
|
|
Boolean empty = entry.type == XmlEntry::EMPTY_TAG; |
|
|
|
// Get PARAMVALUE.NAME attribute: |
|
|
|
if (!entry.getAttributeValue("NAME", name)) |
|
{ |
|
MessageLoaderParms mlParms( |
|
"Common.XmlReader.MISSING_PARAMVALUE_ATTRIBUTE", |
|
"Missing PARAMVALUE.NAME attribute"); |
|
throw XmlValidationError(parser.getLine(), mlParms); |
} | } |
| |
expectContentOrCData(parser, entry); |
// Get PROPERTY.EmbeddedObject |
| |
if (strcmp(entry.text, "TRUE") == 0) |
EmbeddedObjectAttributeType embeddedObject = getEmbeddedObjectAttribute( |
result = true; |
parser.getLine(), entry, "PARAMVALUE"); |
else if (strcmp(entry.text, "FALSE") == 0) |
|
result = false; |
|
else |
|
throw XmlSemanticError(parser.getLine(), |
|
"Bad value for VALUE element: must be \"TRUE\" or \"FALSE\""); |
|
| |
expectEndTag(parser, "VALUE"); |
// Get PARAMVALUE.PARAMTYPE attribute: |
| |
return true; |
Boolean gotType = getCimTypeAttribute(parser.getLine(), entry, type, |
|
"PARAMVALUE", "PARAMTYPE", false); |
|
|
|
if (empty) |
|
{ |
|
gotType = false; // Can't distinguish array and non-array types |
|
} |
|
else |
|
{ |
|
// Parse VALUE.REFERENCE and VALUE.REFARRAY type |
|
if ( (type == CIMTYPE_REFERENCE) || !gotType ) |
|
{ |
|
CIMObjectPath reference; |
|
if (XmlReader::getValueReferenceElement(parser, reference)) |
|
{ |
|
value.set(reference); |
|
type = CIMTYPE_REFERENCE; |
|
gotType = true; |
|
} |
|
else if (XmlReader::getValueReferenceArrayElement(parser, value)) |
|
{ |
|
type = CIMTYPE_REFERENCE; |
|
gotType = true; |
|
} |
|
else |
|
{ |
|
gotType = false; // Can't distinguish array and non-array types |
|
} |
|
} |
|
|
|
// Parse non-reference value |
|
if ( type != CIMTYPE_REFERENCE ) |
|
{ |
|
CIMType effectiveType; |
|
if (!gotType) |
|
{ |
|
// If we don't know what type the value is, read it as a String |
|
effectiveType = CIMTYPE_STRING; |
|
} |
|
else |
|
{ |
|
effectiveType = type; |
} | } |
| |
|
// If the EmbeddedObject attribute is present with value "object" |
|
// then |
|
// Convert the EmbeddedObject-encoded string into a CIMObject |
|
if (embeddedObject != NO_EMBEDDED_OBJECT) |
|
{ |
|
// The EmbeddedObject attribute is only valid on Parameters |
|
// of type string |
|
// The type must have been specified. |
|
if (gotType && (type == CIMTYPE_STRING)) |
|
{ |
|
if (embeddedObject == EMBEDDED_OBJECT_ATTR) |
|
// Used below by getValueElement() or |
|
// getValueArrayElement() |
|
effectiveType = CIMTYPE_OBJECT; |
|
else |
|
effectiveType = CIMTYPE_INSTANCE; |
|
} |
|
else |
|
{ |
|
MessageLoaderParms mlParms( |
|
"Common.XmlReader.INVALID_EMBEDDEDOBJECT_TYPE", |
|
"The EmbeddedObject attribute is only valid on " |
|
"string types."); |
|
throw XmlValidationError(parser.getLine(), mlParms); |
|
} |
|
} |
| |
|
if (!XmlReader::getValueArrayElement(parser, effectiveType, value) |
|
&& !XmlReader::getValueElement(parser, effectiveType, value)) |
|
{ |
|
gotType = false; // Can't distinguish array and non-array types |
|
value.clear(); // Isn't necessary; should already be cleared |
|
} |
|
} |
| |
|
expectEndTag(parser, "PARAMVALUE"); |
|
} |
| |
|
paramValue = CIMParamValue(name, value, gotType); |
| |
|
return true; |
|
} |
| |
//------------------------------------------------------------------------------ | //------------------------------------------------------------------------------ |
// | // |
// getErrorElement() |
// getReturnValueElement() |
// | // |
// <!ELEMENT ERROR EMPTY> |
// <!ELEMENT RETURNVALUE (VALUE|VALUE.REFERENCE)> |
// <!ATTLIST ERROR |
// <!ATTLIST RETURNVALUE |
// CODE CDATA #REQUIRED |
// %EmbeddedObject; #IMPLIED |
// DESCRIPTION CDATA #IMPLIED> |
// %ParamType;> |
// | // |
//------------------------------------------------------------------------------ | //------------------------------------------------------------------------------ |
| |
Boolean XmlReader::getErrorElement( |
Boolean XmlReader::getReturnValueElement( |
XmlParser& parser, | XmlParser& parser, |
CIMException::Code& code, |
CIMValue& returnValue) |
const char*& description, |
|
Boolean required) |
|
{ | { |
XmlEntry entry; | XmlEntry entry; |
|
CIMType type; |
|
CIMValue value; |
| |
if (!testStartTagOrEmptyTag(parser, entry, "ERROR")) |
if (!testStartTag(parser, entry, "RETURNVALUE")) |
{ |
|
if (required) |
|
throw XmlValidationError(parser.getLine(),"Expected ERROR element"); |
|
return false; | return false; |
|
|
|
// Get PROPERTY.EmbeddedObject |
|
|
|
EmbeddedObjectAttributeType embeddedObject = getEmbeddedObjectAttribute( |
|
parser.getLine(), entry, "RETURNVALUE"); |
|
|
|
// Get RETURNVALUE.PARAMTYPE attribute: |
|
// NOTE: Array type return values are not allowed (2/20/02) |
|
|
|
Boolean gotType = getCimTypeAttribute(parser.getLine(), entry, type, |
|
"RETURNVALUE", "PARAMTYPE", false); |
|
|
|
// Parse VALUE.REFERENCE type |
|
if ( (type == CIMTYPE_REFERENCE) || !gotType ) |
|
{ |
|
CIMObjectPath reference; |
|
if (XmlReader::getValueReferenceElement(parser, reference)) |
|
{ |
|
returnValue.set(reference); |
|
type = CIMTYPE_REFERENCE; |
|
gotType = true; |
|
} |
|
else if (type == CIMTYPE_REFERENCE) |
|
{ |
|
MessageLoaderParms mlParms( |
|
"Common.XmlReader.EXPECTED_VALUE_REFERENCE_ELEMENT", |
|
"expected VALUE.REFERENCE element"); |
|
throw XmlValidationError(parser.getLine(), mlParms); |
|
} |
} | } |
| |
Boolean empty = entry.type == XmlEntry::EMPTY_TAG; |
// Parse non-reference return value |
|
if ( type != CIMTYPE_REFERENCE ) |
|
{ |
|
if (!gotType) |
|
{ |
|
// If we don't know what type the value is, read it as a String |
|
type = CIMTYPE_STRING; |
|
} |
|
if (embeddedObject != NO_EMBEDDED_OBJECT) |
|
{ |
|
if (gotType && (type == CIMTYPE_STRING)) |
|
{ |
|
if (embeddedObject == EMBEDDED_OBJECT_ATTR) |
|
// Used below by getValueElement() or getValueArrayElement() |
|
type = CIMTYPE_OBJECT; |
|
else |
|
type = CIMTYPE_INSTANCE; |
|
} |
|
else |
|
{ |
|
MessageLoaderParms mlParms( |
|
"Common.XmlReader.INVALID_EMBEDDEDOBJECT_TYPE", |
|
"The EmbeddedObject attribute is only valid on string " |
|
"types."); |
|
throw XmlValidationError(parser.getLine(), mlParms); |
|
} |
|
} |
|
if ( !XmlReader::getValueElement(parser, type, returnValue) ) |
|
{ |
|
MessageLoaderParms mlParms( |
|
"Common.XmlReader.EXPECTED_VALUE_ELEMENT", |
|
"expected VALUE element"); |
|
throw XmlValidationError(parser.getLine(), mlParms); |
|
} |
|
} |
| |
// Get ERROR.CODE |
expectEndTag(parser, "RETURNVALUE"); |
| |
Uint32 tmpCode; |
return true; |
|
} |
| |
if (!entry.getAttributeValue("CODE", tmpCode)) |
//----------------------------------------------------------------------------- |
throw XmlValidationError( |
// |
parser.getLine(), "missing ERROR.CODE attribute"); |
// The following is a common set of version tests used by the different |
|
// Pegasus Request and Response Decoders |
|
// |
|
//------------------------------------------------------------------------------ |
|
// |
|
// isSupportedCIMVersion() |
|
// tests for valid CIMVersion number |
|
// |
|
// Reject cimVersion not in 2.[0-9]+ |
|
// |
|
// CIMXML Secification, Version 2.2 Final, Sect 3.2.1.1 |
|
// The CIMVERSION attribute defines the version of the CIM Specification to |
|
// which the XML Document conforms. It MUST be in the form of "M.N". Where |
|
// M is the Major Version of the specification in numeric form and N is the |
|
// minor version of the specification in numeric form. For example, "2.0", |
|
// "2.1". Implementations must only validate the major version as all minor |
|
// versions are backward compatible. Implementations may look at the minor |
|
// version to determine additional capabilites. |
|
// |
|
//------------------------------------------------------------------------------ |
|
Boolean XmlReader::isSupportedCIMVersion( |
|
const char* cimVersion) |
|
{ |
|
Boolean cimVersionAccepted = false; |
|
//printf("testCIMVersion %s \n", cimVersion); |
|
if ((cimVersion[0] == '2') && |
|
(cimVersion[1] == '.') && |
|
(cimVersion[2] != 0)) |
|
{ |
|
// Verify that all characters after the '.' are digits |
|
Uint32 index = 2; |
|
while (isdigit(cimVersion[index])) |
|
{ |
|
index++; |
|
} |
|
|
|
if (cimVersion[index] == 0) |
|
{ |
|
cimVersionAccepted = true; |
|
} |
|
} |
|
return cimVersionAccepted; |
|
} |
| |
code = CIMException::Code(tmpCode); |
//------------------------------------------------------------------------------ |
|
// |
|
// isSupportedProtocolVersion() |
|
// tests for valid ProtocolVersion number |
|
// |
|
// Reject ProtocolVersion not 1.[0-9] |
|
// |
|
// cimxml spec 2.2 Final Section 3261 |
|
// The PROTOCOLVERSION attribute defines the version of the CIM Operations to |
|
// which this message conforms. It MUST be in the form of "M.N". Where M is |
|
// the Major Version of the specification in numeric form and N is the minor |
|
// version of the specification in numeric form. For example, "1.0", "1.1". |
|
// Implementations must only validate the major version as all minor versions |
|
// are backward compatible. Implementations may look at the minor version to |
|
// determine additional capabilites. |
|
// |
|
//------------------------------------------------------------------------------ |
|
Boolean XmlReader::isSupportedProtocolVersion( |
|
const String& protocolVersion) |
|
{ |
|
Boolean protocolVersionAccepted = false; |
| |
// Get ERROR.DESCRIPTION: |
//cout << "testProtocolVersion " << protocolVersion << endl; |
|
if ((protocolVersion.size() >= 3) && |
|
(protocolVersion[0] == '1') && |
|
(protocolVersion[1] == '.')) |
|
{ |
|
// Verify that all characters after the '.' are digits |
|
Uint32 index = 2; |
|
while ((index < protocolVersion.size()) && |
|
(protocolVersion[index] >= '0') && |
|
(protocolVersion[index] <= '9')) |
|
{ |
|
index++; |
|
} |
| |
description = ""; |
if (index == protocolVersion.size()) |
entry.getAttributeValue("DESCRIPTION", description); |
{ |
|
protocolVersionAccepted = true; |
|
} |
|
} |
|
return protocolVersionAccepted; |
|
} |
| |
if (!empty) |
//------------------------------------------------------------------------------ |
expectEndTag(parser, "ERROR"); |
// |
|
// isSupportedDTDVersion() |
|
// Tests for Valid dtdVersion number |
|
// We accept DTD version 2.[0-9]+ (see Bugzilla 1556)// |
|
// |
|
// CIM/XML Specification, V 2.2 Final, Section 3.2.1.1 |
|
// The DTDVERSION attribute defines the version of the CIM XML Mapping to |
|
// which the XML Document conforms. It MUST be in the form of "M.N". Where |
|
// M is the Major Version of the specification in numeric form and N is the |
|
// minor version of the specification in numeric form. For example, "2.0", |
|
// "2.1". Implementations must only validate the major version as all minor |
|
// versions are backward compatible. Implementations may look at the minor |
|
// version to determine additional capabilites. |
|
// |
|
//------------------------------------------------------------------------------ |
|
Boolean XmlReader::isSupportedDTDVersion( |
|
const char* dtdVersion) |
|
{ |
|
Boolean dtdVersionAccepted = false; |
| |
return true; |
//printf("testDTDVersion %s \n", dtdVersion); |
|
if ((dtdVersion[0] == '2') && |
|
(dtdVersion[1] == '.') && |
|
(dtdVersion[2] != 0)) |
|
{ |
|
// Verify that all characters after the '.' are digits |
|
Uint32 index = 2; |
|
while (isdigit(dtdVersion[index])) |
|
{ |
|
index++; |
} | } |
| |
|
if (dtdVersion[index] == 0) |
|
{ |
|
dtdVersionAccepted = true; |
|
} |
|
} |
|
return dtdVersionAccepted; |
|
} |
PEGASUS_NAMESPACE_END | PEGASUS_NAMESPACE_END |