version 1.26, 2002/02/20 23:14:19
|
version 1.141, 2006/08/22 18:30:48
|
|
|
//%///////////////////////////////////////////////////////////////////////////// |
//%2006//////////////////////////////////////////////////////////////////////// |
// | // |
// Copyright (c) 2000, 2001 BMC Software, Hewlett-Packard Company, IBM, |
// Copyright (c) 2000, 2001, 2002 BMC Software; Hewlett-Packard Development |
// The Open Group, Tivoli Systems |
// Company, L.P.; IBM Corp.; The Open Group; Tivoli Systems. |
|
// Copyright (c) 2003 BMC Software; Hewlett-Packard Development Company, L.P.; |
|
// IBM Corp.; EMC Corporation, The Open Group. |
|
// Copyright (c) 2004 BMC Software; Hewlett-Packard Development Company, L.P.; |
|
// IBM Corp.; EMC Corporation; VERITAS Software Corporation; The Open Group. |
|
// Copyright (c) 2005 Hewlett-Packard Development Company, L.P.; IBM Corp.; |
|
// EMC Corporation; VERITAS Software Corporation; The Open Group. |
|
// Copyright (c) 2006 Hewlett-Packard Development Company, L.P.; IBM Corp.; |
|
// EMC Corporation; Symantec Corporation; The Open Group. |
// | // |
// Permission is hereby granted, free of charge, to any person obtaining a copy | // Permission is hereby granted, free of charge, to any person obtaining a copy |
// of this software and associated documentation files (the "Software"), to | // of this software and associated documentation files (the "Software"), to |
|
|
// Modified By: Nitin Upasani, Hewlett-Packard Company (Nitin_Upasani@hp.com) | // Modified By: Nitin Upasani, Hewlett-Packard Company (Nitin_Upasani@hp.com) |
// Nag Boranna, Hewlett-Packard Company (nagaraja_boranna@hp.com) | // Nag Boranna, Hewlett-Packard Company (nagaraja_boranna@hp.com) |
// Roger Kumpf, Hewlett-Packard Company (roger_kumpf@hp.com) | // Roger Kumpf, Hewlett-Packard Company (roger_kumpf@hp.com) |
|
// Carol Ann Krug Graves, Hewlett-Packard Company |
|
// (carolann_graves@hp.com) |
|
// Amit K Arora, IBM (amita@in.ibm.com) for PEP#101 |
|
// Brian G. Campbell, EMC (campbell_brian@emc.com) - PEP140/phase1 |
|
// Willis White (whiwill@us.ibm.com) PEP 127 and 128 |
|
// Brian G. Campbell, EMC (campbell_brian@emc.com) - PEP140/phase2 |
|
// Dave Sudlik, IBM (dsudlik@us.ibm.com) |
|
// David Dillard, Symantec Corp. (david_dillard@symantec.com) |
|
// Vijay Eli, vijayeli@in.ibm.com, fix for #2571 |
// | // |
//%///////////////////////////////////////////////////////////////////////////// | //%///////////////////////////////////////////////////////////////////////////// |
| |
|
#include <Pegasus/Common/Config.h> |
#include <cstdlib> | #include <cstdlib> |
#include <cstdio> | #include <cstdio> |
|
#include "Constants.h" |
#include "CIMClass.h" | #include "CIMClass.h" |
|
#include "CIMClassRep.h" |
#include "CIMInstance.h" | #include "CIMInstance.h" |
|
#include "CIMInstanceRep.h" |
|
#include "CIMProperty.h" |
|
#include "CIMPropertyRep.h" |
|
#include "CIMMethod.h" |
|
#include "CIMMethodRep.h" |
|
#include "CIMParameter.h" |
|
#include "CIMParameterRep.h" |
|
#include "CIMParamValue.h" |
|
#include "CIMParamValueRep.h" |
|
#include "CIMQualifier.h" |
|
#include "CIMQualifierRep.h" |
#include "CIMQualifierDecl.h" | #include "CIMQualifierDecl.h" |
|
#include "CIMQualifierDeclRep.h" |
|
#include "CIMValue.h" |
#include "XmlWriter.h" | #include "XmlWriter.h" |
#include "XmlParser.h" | #include "XmlParser.h" |
|
#include "Tracer.h" |
|
#include <Pegasus/Common/StatisticalData.h> |
|
#include "CommonUTF.h" |
|
#include "Buffer.h" |
|
#include "StrLit.h" |
|
#include "LanguageParser.h" |
|
#include "IDFactory.h" |
| |
PEGASUS_NAMESPACE_BEGIN | PEGASUS_NAMESPACE_BEGIN |
| |
inline void AppendChar(Array<Sint8>& out, Char16 c) |
// This is a shortcut macro for outputing content length. This |
|
// pads the output number to the max characters representing a Uint32 number |
|
// so that it can be overwritten easily with a transfer encoding line later |
|
// on in HTTPConnection if required. This is strictly for performance since |
|
// messages can be very large. This overwriting shortcut allows us to NOT have |
|
// to repackage a large message later. |
|
|
|
#define OUTPUT_CONTENTLENGTH \ |
|
{ \ |
|
char contentLengthP[11]; \ |
|
int n = sprintf(contentLengthP,"%.10u", contentLength); \ |
|
out << STRLIT("content-length: "); \ |
|
out.append(contentLengthP, n); \ |
|
out << STRLIT("\r\n"); \ |
|
} |
|
|
|
//////////////////////////////////////////////////////////////////////////////// |
|
// |
|
// SpecialChar and table. |
|
// |
|
//////////////////////////////////////////////////////////////////////////////// |
|
|
|
// Note: we cannot use StrLit here since it has a constructur (forbits |
|
// structure initialization). |
|
|
|
struct SpecialChar |
|
{ |
|
const char* str; |
|
size_t size; |
|
}; |
|
|
|
// Defines encodings of special characters. Just use a 7-bit ASCII character |
|
// as an index into this array to retrieve its string encoding and encoding |
|
// length in bytes. |
|
static const SpecialChar _specialChars[] = |
|
{ |
|
{STRLIT_ARGS("�")}, |
|
{STRLIT_ARGS("")}, |
|
{STRLIT_ARGS("")}, |
|
{STRLIT_ARGS("")}, |
|
{STRLIT_ARGS("")}, |
|
{STRLIT_ARGS("")}, |
|
{STRLIT_ARGS("")}, |
|
{STRLIT_ARGS("")}, |
|
{STRLIT_ARGS("")}, |
|
{STRLIT_ARGS("	")}, |
|
{STRLIT_ARGS(" ")}, |
|
{STRLIT_ARGS("")}, |
|
{STRLIT_ARGS("")}, |
|
{STRLIT_ARGS(" ")}, |
|
{STRLIT_ARGS("")}, |
|
{STRLIT_ARGS("")}, |
|
{STRLIT_ARGS("")}, |
|
{STRLIT_ARGS("")}, |
|
{STRLIT_ARGS("")}, |
|
{STRLIT_ARGS("")}, |
|
{STRLIT_ARGS("")}, |
|
{STRLIT_ARGS("")}, |
|
{STRLIT_ARGS("")}, |
|
{STRLIT_ARGS("")}, |
|
{STRLIT_ARGS("")}, |
|
{STRLIT_ARGS("")}, |
|
{STRLIT_ARGS("")}, |
|
{STRLIT_ARGS("")}, |
|
{STRLIT_ARGS("")}, |
|
{STRLIT_ARGS("")}, |
|
{STRLIT_ARGS("")}, |
|
{STRLIT_ARGS("")}, |
|
{STRLIT_ARGS(" ")}, |
|
{STRLIT_ARGS("!")}, |
|
{STRLIT_ARGS(""")}, |
|
{STRLIT_ARGS("#")}, |
|
{STRLIT_ARGS("$")}, |
|
{STRLIT_ARGS("%")}, |
|
{STRLIT_ARGS("&")}, |
|
{STRLIT_ARGS("'")}, |
|
{STRLIT_ARGS("(")}, |
|
{STRLIT_ARGS(")")}, |
|
{STRLIT_ARGS("*")}, |
|
{STRLIT_ARGS("+")}, |
|
{STRLIT_ARGS(",")}, |
|
{STRLIT_ARGS("-")}, |
|
{STRLIT_ARGS(".")}, |
|
{STRLIT_ARGS("/")}, |
|
{STRLIT_ARGS("0")}, |
|
{STRLIT_ARGS("1")}, |
|
{STRLIT_ARGS("2")}, |
|
{STRLIT_ARGS("3")}, |
|
{STRLIT_ARGS("4")}, |
|
{STRLIT_ARGS("5")}, |
|
{STRLIT_ARGS("6")}, |
|
{STRLIT_ARGS("7")}, |
|
{STRLIT_ARGS("8")}, |
|
{STRLIT_ARGS("9")}, |
|
{STRLIT_ARGS(":")}, |
|
{STRLIT_ARGS(";")}, |
|
{STRLIT_ARGS("<")}, |
|
{STRLIT_ARGS("=")}, |
|
{STRLIT_ARGS(">")}, |
|
{STRLIT_ARGS("?")}, |
|
{STRLIT_ARGS("@")}, |
|
{STRLIT_ARGS("A")}, |
|
{STRLIT_ARGS("B")}, |
|
{STRLIT_ARGS("C")}, |
|
{STRLIT_ARGS("D")}, |
|
{STRLIT_ARGS("E")}, |
|
{STRLIT_ARGS("F")}, |
|
{STRLIT_ARGS("G")}, |
|
{STRLIT_ARGS("H")}, |
|
{STRLIT_ARGS("I")}, |
|
{STRLIT_ARGS("J")}, |
|
{STRLIT_ARGS("K")}, |
|
{STRLIT_ARGS("L")}, |
|
{STRLIT_ARGS("M")}, |
|
{STRLIT_ARGS("N")}, |
|
{STRLIT_ARGS("O")}, |
|
{STRLIT_ARGS("P")}, |
|
{STRLIT_ARGS("Q")}, |
|
{STRLIT_ARGS("R")}, |
|
{STRLIT_ARGS("S")}, |
|
{STRLIT_ARGS("T")}, |
|
{STRLIT_ARGS("U")}, |
|
{STRLIT_ARGS("V")}, |
|
{STRLIT_ARGS("W")}, |
|
{STRLIT_ARGS("X")}, |
|
{STRLIT_ARGS("Y")}, |
|
{STRLIT_ARGS("Z")}, |
|
{STRLIT_ARGS("[")}, |
|
{STRLIT_ARGS("\\")}, |
|
{STRLIT_ARGS("]")}, |
|
{STRLIT_ARGS("^")}, |
|
{STRLIT_ARGS("_")}, |
|
{STRLIT_ARGS("`")}, |
|
{STRLIT_ARGS("a")}, |
|
{STRLIT_ARGS("b")}, |
|
{STRLIT_ARGS("c")}, |
|
{STRLIT_ARGS("d")}, |
|
{STRLIT_ARGS("e")}, |
|
{STRLIT_ARGS("f")}, |
|
{STRLIT_ARGS("g")}, |
|
{STRLIT_ARGS("h")}, |
|
{STRLIT_ARGS("i")}, |
|
{STRLIT_ARGS("j")}, |
|
{STRLIT_ARGS("k")}, |
|
{STRLIT_ARGS("l")}, |
|
{STRLIT_ARGS("m")}, |
|
{STRLIT_ARGS("n")}, |
|
{STRLIT_ARGS("o")}, |
|
{STRLIT_ARGS("p")}, |
|
{STRLIT_ARGS("q")}, |
|
{STRLIT_ARGS("r")}, |
|
{STRLIT_ARGS("s")}, |
|
{STRLIT_ARGS("t")}, |
|
{STRLIT_ARGS("u")}, |
|
{STRLIT_ARGS("v")}, |
|
{STRLIT_ARGS("w")}, |
|
{STRLIT_ARGS("x")}, |
|
{STRLIT_ARGS("y")}, |
|
{STRLIT_ARGS("z")}, |
|
{STRLIT_ARGS("{")}, |
|
{STRLIT_ARGS("|")}, |
|
{STRLIT_ARGS("}")}, |
|
{STRLIT_ARGS("~")}, |
|
{STRLIT_ARGS("")}, |
|
}; |
|
|
|
// If _isSpecialChar7[ch] is true, then ch is a special character, which must |
|
// have a special encoding in XML. But only use 7-bit ASCII characters to |
|
// index this array. |
|
static const int _isSpecialChar7[] = |
|
{ |
|
1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,0,0,1,0,0, |
|
0,1,1,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,1,0,1,0,0,0,0,0,0,0,0,0,0,0, |
|
0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, |
|
0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,1, |
|
}; |
|
|
|
//////////////////////////////////////////////////////////////////////////////// |
|
|
|
Buffer& operator<<(Buffer& out, const Char16& x) |
|
{ |
|
XmlWriter::append(out, x); |
|
return out; |
|
} |
|
|
|
Buffer& operator<<(Buffer& out, const String& x) |
|
{ |
|
XmlWriter::append(out, x); |
|
return out; |
|
} |
|
|
|
Buffer& operator<<(Buffer& out, const Indentor& x) |
|
{ |
|
XmlWriter::append(out, x); |
|
return out; |
|
} |
|
|
|
Buffer& operator<<(Buffer& out, const Buffer& x) |
|
{ |
|
out.append(x.getData(), x.size()); |
|
return out; |
|
} |
|
|
|
Buffer& operator<<(Buffer& out, Uint32 x) |
|
{ |
|
XmlWriter::append(out, x); |
|
return out; |
|
} |
|
|
|
Buffer& operator<<(Buffer& out, const CIMName& name) |
|
{ |
|
XmlWriter::append(out, name.getString ()); |
|
return out; |
|
} |
|
|
|
|
|
// l10n |
|
Buffer& operator<<(Buffer& out, const AcceptLanguageList& al) |
{ | { |
out.append(Sint8(c)); |
XmlWriter::append(out, LanguageParser::buildAcceptLanguageHeader(al)); |
|
return out; |
|
} |
|
|
|
// l10n |
|
Buffer& operator<<(Buffer& out, const ContentLanguageList& cl) |
|
{ |
|
XmlWriter::append(out, LanguageParser::buildContentLanguageHeader(cl)); |
|
return out; |
|
} |
|
|
|
|
|
PEGASUS_STD(ostream)& operator<<(PEGASUS_STD(ostream)& os, const CIMDateTime& x) |
|
{ |
|
return os << x.toString(); |
|
} |
|
|
|
PEGASUS_STD(ostream)& operator<<(PEGASUS_STD(ostream)& os, const CIMName& name) |
|
{ |
|
os << name.getString(); |
|
return os; |
|
} |
|
|
|
PEGASUS_STD(ostream)& operator<<(PEGASUS_STD(ostream)& os, |
|
const CIMNamespaceName& name) |
|
{ |
|
os << name.getString(); |
|
return os; |
|
} |
|
|
|
static void _xmlWritter_appendChar(Buffer& out, const Char16& c) |
|
{ |
|
// We need to convert the Char16 to UTF8 then append the UTF8 |
|
// character into the array. |
|
// NOTE: The UTF8 character could be several bytes long. |
|
// WARNING: This function will put in replacement character for |
|
// all characters that have surogate pairs. |
|
char str[6]; |
|
memset(str,0x00,sizeof(str)); |
|
Uint8* charIN = (Uint8 *)&c; |
|
|
|
const Uint16 *strsrc = (Uint16 *)charIN; |
|
Uint16 *endsrc = (Uint16 *)&charIN[1]; |
|
|
|
Uint8 *strtgt = (Uint8 *)str; |
|
Uint8 *endtgt = (Uint8 *)&str[5]; |
|
|
|
UTF16toUTF8(&strsrc, |
|
endsrc, |
|
&strtgt, |
|
endtgt); |
|
|
|
out.append(str, UTF_8_COUNT_TRAIL_BYTES(str[0]) + 1); |
|
} |
|
|
|
inline void _appendSpecialChar7(Buffer& out, char c) |
|
{ |
|
if (_isSpecialChar7[int(c)]) |
|
out.append(_specialChars[int(c)].str, _specialChars[int(c)].size); |
|
else |
|
out.append(c); |
} | } |
| |
inline void AppendSpecialChar(Array<Sint8>& out, Char16 c) |
inline void _xmlWritter_appendSpecialChar(Buffer& out, const Char16& c) |
{ | { |
// ATTN-B: Only UTF-8 handled for now. |
if (c < 128) |
|
_appendSpecialChar7(out, char(c)); |
|
else |
|
_xmlWritter_appendChar(out, c); |
|
} |
| |
|
static void _xmlWritter_appendSpecialChar(PEGASUS_STD(ostream)& os, char c) |
|
{ |
|
if ( ((c < 0x20) && (c >= 0)) || (c == 0x7f) ) |
|
{ |
|
char charref[7]; |
|
sprintf(charref, "&#%u;", static_cast<Uint8>(c)); |
|
os << charref; |
|
} |
|
else |
|
{ |
switch (c) | switch (c) |
{ | { |
case '&': | case '&': |
out.append("&", 5); |
os << "&"; |
break; | break; |
| |
case '<': | case '<': |
out.append("<", 4); |
os << "<"; |
break; | break; |
| |
case '>': | case '>': |
out.append(">", 4); |
os << ">"; |
break; | break; |
| |
case '"': | case '"': |
out.append(""", 6); |
os << """; |
break; | break; |
| |
case '\'': | case '\'': |
out.append("'", 6); |
os << "'"; |
break; | break; |
| |
default: | default: |
out.append(Sint8(c)); |
os << c; |
|
} |
|
} |
|
} |
|
|
|
void _xmlWritter_appendSurrogatePair(Buffer& out, Uint16 high, Uint16 low) |
|
{ |
|
char str[6]; |
|
Uint8 charIN[5]; |
|
memset(str,0x00,sizeof(str)); |
|
memcpy(&charIN,&high,2); |
|
memcpy(&charIN[2],&low,2); |
|
const Uint16 *strsrc = (Uint16 *)charIN; |
|
Uint16 *endsrc = (Uint16 *)&charIN[3]; |
|
|
|
Uint8 *strtgt = (Uint8 *)str; |
|
Uint8 *endtgt = (Uint8 *)&str[5]; |
|
|
|
UTF16toUTF8(&strsrc, |
|
endsrc, |
|
&strtgt, |
|
endtgt); |
|
|
|
Uint32 number1 = UTF_8_COUNT_TRAIL_BYTES(str[0]) + 1; |
|
out.append(str,number1); |
|
} |
|
|
|
inline void _xmlWritter_appendSpecial(PEGASUS_STD(ostream)& os, const char* str) |
|
{ |
|
while (*str) |
|
_xmlWritter_appendSpecialChar(os, *str++); |
|
} |
|
|
|
void XmlWriter::append(Buffer& out, const Char16& x) |
|
{ |
|
_xmlWritter_appendChar(out, x); |
} | } |
|
|
|
void XmlWriter::append(Buffer& out, Boolean x) |
|
{ |
|
append(out, (x ? "TRUE" : "FALSE")); |
} | } |
| |
void XmlWriter::append(Array<Sint8>& out, Char16 x) |
void XmlWriter::append(Buffer& out, Uint32 x) |
{ | { |
AppendChar(out, x); |
char buffer[32]; |
|
sprintf(buffer, "%u", x); |
|
append(out, buffer); |
} | } |
| |
void XmlWriter::append(Array<Sint8>& out, Uint32 x) |
void XmlWriter::append(Buffer& out, Sint32 x) |
{ | { |
char buffer[32]; | char buffer[32]; |
sprintf(buffer, "%d", x); | sprintf(buffer, "%d", x); |
append(out, buffer); | append(out, buffer); |
} | } |
| |
void XmlWriter::append(Array<Sint8>& out, const char* str) |
void XmlWriter::append(Buffer& out, Uint64 x) |
{ | { |
while (*str) |
char buffer[32]; // Should need 21 chars max |
AppendChar(out, *str++); |
sprintf(buffer, "%" PEGASUS_64BIT_CONVERSION_WIDTH "u", x); |
|
append(out, buffer); |
} | } |
| |
void XmlWriter::appendSpecial(Array<Sint8>& out, Char16 x) |
void XmlWriter::append(Buffer& out, Sint64 x) |
{ | { |
AppendSpecialChar(out, x); |
char buffer[32]; // Should need 21 chars max |
|
sprintf(buffer, "%" PEGASUS_64BIT_CONVERSION_WIDTH "d", x); |
|
append(out, buffer); |
} | } |
| |
void XmlWriter::appendSpecial(Array<Sint8>& out, char x) |
void XmlWriter::append(Buffer& out, Real32 x) |
{ | { |
AppendSpecialChar(out, Char16(x)); |
char buffer[128]; |
|
// %.7e gives '[-]m.ddddddde+/-xx', which seems compatible with the format |
|
// given in the CIM/XML spec, and the precision required by the CIM 2.2 spec |
|
// (4 byte IEEE floating point) |
|
sprintf(buffer, "%.7e", x); |
|
append(out, buffer); |
} | } |
| |
void XmlWriter::appendSpecial(Array<Sint8>& out, const char* str) |
void XmlWriter::append(Buffer& out, Real64 x) |
{ | { |
while (*str) |
char buffer[128]; |
AppendSpecialChar(out, *str++); |
// %.16e gives '[-]m.dddddddddddddddde+/-xx', which seems compatible with the format |
|
// given in the CIM/XML spec, and the precision required by the CIM 2.2 spec |
|
// (8 byte IEEE floating point) |
|
sprintf(buffer, "%.16e", x); |
|
append(out, buffer); |
} | } |
| |
void XmlWriter::appendSpecial(Array<Sint8>& out, const String& str) |
void XmlWriter::append(Buffer& out, const char* str) |
{ | { |
const Char16* tmp = str.getData(); |
size_t n = strlen(str); |
|
out.append(str, n); |
|
} |
|
|
|
void XmlWriter::append(Buffer& out, const String& str) |
|
{ |
|
const Uint16* p = (const Uint16*)str.getChar16Data(); |
|
size_t n = str.size(); |
|
|
|
// Handle leading ASCII 7 characers in these next two loops (use unrolling). |
|
|
|
while (n >= 8 && ((p[0]|p[1]|p[2]|p[3]|p[4]|p[5]|p[6]|p[7]) & 0xFF80) == 0) |
|
{ |
|
out.append(p[0], p[1], p[2], p[3], p[4], p[5], p[6], p[7]); |
|
p += 8; |
|
n -= 8; |
|
} |
|
|
|
while (n >= 4 && ((p[0]|p[1]|p[2]|p[3]) & 0xFF80) == 0) |
|
{ |
|
out.append(p[0], p[1], p[2], p[3]); |
|
p += 4; |
|
n -= 4; |
|
} |
|
|
|
while (n--) |
|
{ |
|
Uint16 c = *p++; |
| |
while (*tmp) |
// Special processing for UTF8 case: |
AppendSpecialChar(out, *tmp++); |
|
|
if (c < 128) |
|
{ |
|
out.append(c); |
|
continue; |
} | } |
| |
void XmlWriter::append(Array<Sint8>& out, const String& str) |
// Hanlde UTF8 case (if reached). |
|
|
|
if(((c >= FIRST_HIGH_SURROGATE) && (c <= LAST_HIGH_SURROGATE)) || |
|
((c >= FIRST_LOW_SURROGATE) && (c <= LAST_LOW_SURROGATE))) |
{ | { |
const Char16* tmp = str.getData(); |
Char16 highSurrogate = p[-1]; |
|
Char16 lowSurrogate = p[0]; |
|
p++; |
|
n--; |
| |
while (*tmp) |
_xmlWritter_appendSurrogatePair( |
AppendChar(out, *tmp++); |
out, Uint16(highSurrogate),Uint16(lowSurrogate)); |
|
} |
|
else |
|
{ |
|
_xmlWritter_appendChar(out, c); |
|
} |
|
} |
} | } |
| |
void XmlWriter::append(Array<Sint8>& out, const Indentor& x) |
void XmlWriter::append(Buffer& out, const Indentor& x) |
{ | { |
for (Uint32 i = 0; i < 4 * x.getLevel(); i++) | for (Uint32 i = 0; i < 4 * x.getLevel(); i++) |
out.append(' '); | out.append(' '); |
} | } |
| |
void XmlWriter::appendLocalNameSpaceElement( |
void XmlWriter::appendSpecial(Buffer& out, const Char16& x) |
Array<Sint8>& out, |
|
const String& nameSpace) |
|
{ | { |
out << "<LOCALNAMESPACEPATH>\n"; |
_xmlWritter_appendSpecialChar(out, x); |
|
} |
| |
char* tmp = nameSpace.allocateCString(); |
void XmlWriter::appendSpecial(Buffer& out, char x) |
|
{ |
|
_appendSpecialChar7(out, x); |
|
} |
| |
for (char* p = strtok(tmp, "/"); p; p = strtok(NULL, "/")) |
void XmlWriter::appendSpecial(Buffer& out, const char* str) |
{ | { |
out << "<NAMESPACE NAME=\"" << p << "\"/>\n"; |
while (*str) |
|
_appendSpecialChar7(out, *str++); |
} | } |
| |
delete [] tmp; |
void XmlWriter::appendSpecial(Buffer& out, const String& str) |
|
{ |
|
const Uint16* p = (const Uint16*)str.getChar16Data(); |
|
// prevCharIsSpace is true when the last character written to the Buffer |
|
// is a space character (not a character reference). |
|
Boolean prevCharIsSpace = false; |
| |
out << "</LOCALNAMESPACEPATH>\n"; |
// If the first character is a space, use a character reference to avoid |
|
// space compression. |
|
if (*p == ' ') |
|
{ |
|
out.append(STRLIT_ARGS(" ")); |
|
p++; |
} | } |
| |
static inline void AppendSpecialChar(PEGASUS_STD(ostream)& os, char c) |
Uint16 c; |
|
while ((c = *p++) != 0) |
{ | { |
switch (c) |
if (c < 128) |
{ | { |
case '&': |
if (_isSpecialChar7[c]) |
os << "&"; |
{ |
break; |
// Write the character reference for the special character |
|
out.append( |
|
_specialChars[int(c)].str, _specialChars[int(c)].size); |
|
prevCharIsSpace = false; |
|
} |
|
else if (prevCharIsSpace && (c == ' ')) |
|
{ |
|
// Write the character reference for the space character, to |
|
// avoid compression |
|
out.append(STRLIT_ARGS(" ")); |
|
prevCharIsSpace = false; |
|
} |
|
else |
|
{ |
|
out.append(c); |
|
prevCharIsSpace = (c == ' '); |
|
} |
|
} |
|
else |
|
{ |
|
// Handle UTF8 case |
| |
case '<': |
if ((((c >= FIRST_HIGH_SURROGATE) && (c <= LAST_HIGH_SURROGATE)) || |
os << "<"; |
((c >= FIRST_LOW_SURROGATE) && (c <= LAST_LOW_SURROGATE))) && |
break; |
*p) |
|
{ |
|
_xmlWritter_appendSurrogatePair(out, c, *p++); |
|
} |
|
else |
|
{ |
|
_xmlWritter_appendChar(out, c); |
|
} |
| |
case '>': |
prevCharIsSpace = false; |
os << ">"; |
} |
break; |
} |
| |
case '"': |
// If the last character is a space, use a character reference to avoid |
os << """; |
// space compression. |
break; |
if (prevCharIsSpace) |
|
{ |
|
out.remove(out.size() - 1); |
|
out.append(STRLIT_ARGS(" ")); |
|
} |
|
} |
| |
case '\'': |
// See http://www.ietf.org/rfc/rfc2396.txt section 2 |
os << "'"; |
// Reserved characters = ';' '/' '?' ':' '@' '&' '=' '+' '$' ',' |
break; |
// Excluded characters: |
|
// Control characters = 0x00-0x1f, 0x7f |
|
// Space character = 0x20 |
|
// Delimiters = '<' '>' '#' '%' '"' |
|
// Unwise = '{' '}' '|' '\\' '^' '[' ']' '`' |
|
// |
| |
default: |
static const char _is_uri[128] = |
os << c; |
{ |
|
1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,0,1,1,1, |
|
1,1,0,0,0,0,1,1,0,0,1,0,0,0,0,0,0,0,0,0,0,1,1,1,1,1,1,1,0,0,0,0,0,0,0,0,0, |
|
0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,1,1,1,1,0,1,0,0,0,0,0,0,0,0,0,0,0,0,0,0, |
|
0,0,0,0,0,0,0,0,0,0,0,0,1,1,1,0,1, |
|
}; |
|
|
|
// Perform the necessary URI encoding of characters in HTTP header values. |
|
// This is required by the HTTP/1.1 specification and the CIM/HTTP |
|
// Specification (section 3.3.2). |
|
static void _xmlWritter_encodeURIChar(String& outString, Sint8 char8) |
|
{ |
|
Uint8 c = (Uint8)char8; |
|
|
|
#ifndef PEGASUS_DO_NOT_IMPLEMENT_URI_ENCODING |
|
if (c > 127 || _is_uri[int(c)]) |
|
{ |
|
char hexencoding[4]; |
|
int n = sprintf(hexencoding, "%%%X%X", c/16, c%16); |
|
#ifdef PEGASUS_USE_STRING_EXTENSIONS |
|
outString.append(hexencoding, n); |
|
#else /* PEGASUS_USE_STRING_EXTENSIONS */ |
|
outString.append(hexencoding); |
|
#endif /* PEGASUS_USE_STRING_EXTENSIONS */ |
|
} |
|
else |
|
#endif |
|
{ |
|
outString.append((Uint16)c); |
} | } |
} | } |
| |
static inline void AppendSpecial(PEGASUS_STD(ostream)& os, const char* str) |
String XmlWriter::encodeURICharacters(const Buffer& uriString) |
{ | { |
while (*str) |
String encodedString; |
AppendSpecialChar(os, *str++); |
|
|
for (Uint32 i=0; i<uriString.size(); i++) |
|
{ |
|
_xmlWritter_encodeURIChar(encodedString, uriString[i]); |
} | } |
| |
//------------------------------------------------------------------------------ |
return encodedString; |
// |
} |
// formatGetHeader() |
|
// |
String XmlWriter::encodeURICharacters(const String& uriString) |
//------------------------------------------------------------------------------ |
{ |
|
String encodedString; |
| |
Array<Sint8> XmlWriter::formatGetHeader( |
/* i18n remove - did not handle surrogate pairs |
const char* documentPath) |
for (Uint32 i=0; i<uriString.size(); i++) |
{ | { |
Array<Sint8> out; |
_xmlWritter_encodeURIChar(encodedString, uriString[i]); |
return out << "GET " << documentPath << "HTTP/1.0\r\n\r\n"; |
|
} | } |
|
*/ |
| |
//------------------------------------------------------------------------------ |
// See the "CIM Operations over HTTP" spec, section 3.3.2 and |
// |
// 3.3.3, for the treatment of non US-ASCII (UTF-8) chars |
// formatMPostHeader() |
|
// |
|
// Build HTTP request header. |
|
// |
|
//------------------------------------------------------------------------------ |
|
| |
Array<Sint8> XmlWriter::formatMPostHeader( |
// First, convert to UTF-8 (include handling of surrogate pairs) |
const char* host, |
Buffer utf8; |
const char* cimOperation, |
for (Uint32 i = 0; i < uriString.size(); i++) |
const char* cimMethod, |
|
const String& cimObject, |
|
const String& authenticationHeader, |
|
const Array<Sint8>& content) |
|
{ | { |
Array<Sint8> out; |
Uint16 c = uriString[i]; |
out.reserve(1024); |
|
char nn[] = { '0' + (rand() % 10), '0' + (rand() % 10), '\0' }; |
|
| |
out << "M-POST /cimom HTTP/1.1\r\n"; |
if(((c >= FIRST_HIGH_SURROGATE) && (c <= LAST_HIGH_SURROGATE)) || |
out << "HOST: " << host << "\r\n"; |
((c >= FIRST_LOW_SURROGATE) && (c <= LAST_LOW_SURROGATE))) |
out << "Content-CIMType: application/xml; charset=\"utf-8\"\r\n"; |
|
out << "Content-Length: " << content.size() << "\r\n"; |
|
out << "Man: http://www.dmtf.org/cim/mapping/http/v1.0; ns="; |
|
out << nn <<"\r\n"; |
|
out << nn << "-CIMOperation: " << cimOperation << "\r\n"; |
|
out << nn << "-CIMMethod: " << cimMethod << "\r\n"; |
|
out << nn << "-CIMObject: " << cimObject << "\r\n"; |
|
if (authenticationHeader.size()) |
|
{ | { |
out << authenticationHeader << "\r\n"; |
Char16 highSurrogate = uriString[i]; |
|
Char16 lowSurrogate = uriString[++i]; |
|
|
|
_xmlWritter_appendSurrogatePair(utf8, Uint16(highSurrogate),Uint16(lowSurrogate)); |
} | } |
out << "\r\n"; |
else |
out << content; |
{ |
return out; |
_xmlWritter_appendChar(utf8, uriString[i]); |
|
} |
|
} |
|
|
|
// Second, escape the non HTTP-safe chars |
|
for (Uint32 i=0; i<utf8.size(); i++) |
|
{ |
|
_xmlWritter_encodeURIChar(encodedString, utf8[i]); |
|
} |
|
|
|
return encodedString; |
} | } |
| |
//------------------------------------------------------------------------------ | //------------------------------------------------------------------------------ |
// | // |
// formatMethodResponseHeader() |
// appendLocalNameSpacePathElement() |
// | // |
// Build HTTP response header. |
// <!ELEMENT LOCALNAMESPACEPATH (NAMESPACE+)> |
// | // |
//------------------------------------------------------------------------------ | //------------------------------------------------------------------------------ |
| |
Array<Sint8> XmlWriter::formatMethodResponseHeader( |
void XmlWriter::appendLocalNameSpacePathElement( |
const Array<Sint8>& content) |
Buffer& out, |
|
const CIMNamespaceName& nameSpace) |
{ | { |
Array<Sint8> out; |
out << STRLIT("<LOCALNAMESPACEPATH>\n"); |
out.reserve(1024); |
|
char nn[] = { '0' + (rand() % 10), '0' + (rand() % 10), '\0' }; |
|
| |
out << "HTTP/1.1 200 OK\r\n"; |
char* nameSpaceCopy = strdup(nameSpace.getString().getCString()); |
out << "Content-CIMType: application/xml; charset=\"utf-8\"\r\n"; |
|
out << "Content-Length: " << content.size() << "\r\n"; |
#if !defined(PEGASUS_COMPILER_MSVC) && !defined(PEGASUS_OS_ZOS) |
out << "Ext:\r\n"; |
char *last; |
out << "Cache-Control: no-cache\r\n"; |
for (const char* p = strtok_r(nameSpaceCopy, "/", &last); p; |
out << "Man: http://www.dmtf.org/cim/mapping/http/v1.0; ns="; |
p = strtok_r(NULL, "/", &last)) |
out << nn <<"\r\n"; |
#else |
out << nn << "-CIMOperation: MethodResponse\r\n\r\n"; |
for (const char* p = strtok(nameSpaceCopy, "/"); p; p = strtok(NULL, "/")) |
out << content; |
#endif |
return out; |
{ |
|
out << STRLIT("<NAMESPACE NAME=\"") << p << STRLIT("\"/>\n"); |
|
} |
|
free(nameSpaceCopy); |
|
|
|
out << STRLIT("</LOCALNAMESPACEPATH>\n"); |
} | } |
| |
//------------------------------------------------------------------------------ | //------------------------------------------------------------------------------ |
// | // |
// formatMessageElement() |
// appendNameSpacePathElement() |
// | // |
// <!ELEMENT MESSAGE (SIMPLEREQ|MULTIREQ|SIMPLERSP|MULTIRSP)> |
// <!ELEMENT NAMESPACEPATH (HOST,LOCALNAMESPACEPATH)> |
// <!ATTLIST MESSAGE |
|
// ID CDATA #REQUIRED |
|
// PROTOCOLVERSION CDATA #REQUIRED> |
|
// | // |
//------------------------------------------------------------------------------ | //------------------------------------------------------------------------------ |
| |
Array<Sint8> XmlWriter::formatMessageElement( |
void XmlWriter::appendNameSpacePathElement( |
const String& messageId, |
Buffer& out, |
const Array<Sint8>& body) |
const String& host, |
|
const CIMNamespaceName& nameSpace) |
{ | { |
Array<Sint8> out; |
out << STRLIT("<NAMESPACEPATH>\n"); |
out.reserve(1024); |
out << STRLIT("<HOST>") << host << STRLIT("</HOST>\n"); |
|
appendLocalNameSpacePathElement(out, nameSpace); |
out << "<?xml version=\"1.0\" encoding=\"utf-8\" ?>\n"; |
out << STRLIT("</NAMESPACEPATH>\n"); |
out << "<CIM CIMVERSION=\"2.0\" DTDVERSION=\"2.0\">\n"; |
|
out << "<MESSAGE ID=\"" << messageId << "\" PROTOCOLVERSION=\"1.0\">\n"; |
|
out << body; |
|
out << "</MESSAGE>\n"; |
|
out << "</CIM>\n"; |
|
return out; |
|
} | } |
| |
//------------------------------------------------------------------------------ | //------------------------------------------------------------------------------ |
// | // |
// formatSimpleReqElement() |
// appendClassNameElement() |
// | // |
// <!ELEMENT SIMPLEREQ (IMETHODCALL|METHODCALL)> |
// <!ELEMENT CLASSNAME EMPTY> |
|
// <!ATTLIST CLASSNAME |
|
// %CIMName;> |
// | // |
//------------------------------------------------------------------------------ | //------------------------------------------------------------------------------ |
| |
Array<Sint8> XmlWriter::formatSimpleReqElement( |
void XmlWriter::appendClassNameElement( |
const Array<Sint8>& body) |
Buffer& out, |
|
const CIMName& className) |
{ | { |
Array<Sint8> out; |
out << STRLIT("<CLASSNAME NAME=\"") << className << STRLIT("\"/>\n"); |
return out << "<SIMPLEREQ>\n" << body << "</SIMPLEREQ>\n"; |
|
} | } |
| |
//------------------------------------------------------------------------------ | //------------------------------------------------------------------------------ |
// | // |
// formatSimpleRspElement() |
// appendInstanceNameElement() |
// | // |
// <!ELEMENT SIMPLERSP (METHODRESPONSE|IMETHODRESPONSE)> |
// <!ELEMENT INSTANCENAME (KEYBINDING*|KEYVALUE?|VALUE.REFERENCE?)> |
|
// <!ATTLIST INSTANCENAME |
|
// %ClassName;> |
// | // |
//------------------------------------------------------------------------------ | //------------------------------------------------------------------------------ |
| |
Array<Sint8> XmlWriter::formatSimpleRspElement( |
void XmlWriter::appendInstanceNameElement( |
const Array<Sint8>& body) |
Buffer& out, |
|
const CIMObjectPath& instanceName) |
|
{ |
|
out << STRLIT("<INSTANCENAME CLASSNAME=\""); |
|
out << instanceName.getClassName() << STRLIT("\">\n"); |
|
|
|
const Array<CIMKeyBinding>& keyBindings = instanceName.getKeyBindings(); |
|
for (Uint32 i = 0, n = keyBindings.size(); i < n; i++) |
|
{ |
|
out << STRLIT("<KEYBINDING NAME=\""); |
|
out << keyBindings[i].getName() << STRLIT("\">\n"); |
|
|
|
if (keyBindings[i].getType() == CIMKeyBinding::REFERENCE) |
{ | { |
Array<Sint8> out; |
CIMObjectPath ref = keyBindings[i].getValue(); |
return out << "<SIMPLERSP>\n" << body << "</SIMPLERSP>\n"; |
appendValueReferenceElement(out, ref, true); |
|
} |
|
else { |
|
out << STRLIT("<KEYVALUE VALUETYPE=\""); |
|
out << keyBindingTypeToString(keyBindings[i].getType()); |
|
out << STRLIT("\">"); |
|
|
|
// fixed the special character problem - Markus |
|
|
|
appendSpecial(out, keyBindings[i].getValue()); |
|
out << STRLIT("</KEYVALUE>\n"); |
|
} |
|
out << STRLIT("</KEYBINDING>\n"); |
|
} |
|
out << STRLIT("</INSTANCENAME>\n"); |
} | } |
| |
//------------------------------------------------------------------------------ | //------------------------------------------------------------------------------ |
// | // |
// formatIMethodCallElement() |
// appendClassPathElement() |
// | // |
// <!ELEMENT IMETHODCALL (LOCALNAMESPACEPATH,IPARAMVALUE*)> |
// <!ELEMENT CLASSPATH (NAMESPACEPATH,CLASSNAME)> |
// <!ATTLIST IMETHODCALL %CIMName;> |
|
// | // |
//------------------------------------------------------------------------------ | //------------------------------------------------------------------------------ |
| |
Array<Sint8> XmlWriter::formatIMethodCallElement( |
void XmlWriter::appendClassPathElement( |
const char* name, |
Buffer& out, |
const String& nameSpace, |
const CIMObjectPath& classPath) |
const Array<Sint8>& iParamValues) |
|
{ | { |
Array<Sint8> out; |
out << STRLIT("<CLASSPATH>\n"); |
out << "<IMETHODCALL NAME=\"" << name << "\">\n"; |
appendNameSpacePathElement(out, |
XmlWriter::appendLocalNameSpaceElement(out, nameSpace); |
classPath.getHost(), |
out << iParamValues; |
classPath.getNameSpace()); |
out << "</IMETHODCALL>\n"; |
appendClassNameElement(out, classPath.getClassName()); |
return out; |
out << STRLIT("</CLASSPATH>\n"); |
} | } |
| |
//------------------------------------------------------------------------------ | //------------------------------------------------------------------------------ |
// | // |
// formatIMethodResponseElement() |
// appendInstancePathElement() |
// | // |
// <!ELEMENT IMETHODRESPONSE (ERROR|IRETURNVALUE?)> |
// <!ELEMENT INSTANCEPATH (NAMESPACEPATH,INSTANCENAME)> |
// <!ATTLIST IMETHODRESPONSE %CIMName;> |
|
// | // |
//------------------------------------------------------------------------------ | //------------------------------------------------------------------------------ |
| |
Array<Sint8> XmlWriter::formatIMethodResponseElement( |
void XmlWriter::appendInstancePathElement( |
const char* name, |
Buffer& out, |
const Array<Sint8>& body) |
const CIMObjectPath& instancePath) |
{ | { |
Array<Sint8> out; |
out << STRLIT("<INSTANCEPATH>\n"); |
out << "<IMETHODRESPONSE NAME=\"" << name << "\">\n"; |
appendNameSpacePathElement(out, |
out << body; |
instancePath.getHost(), |
out << "</IMETHODRESPONSE>\n"; |
instancePath.getNameSpace()); |
return out; |
appendInstanceNameElement(out, instancePath); |
|
out << STRLIT("</INSTANCEPATH>\n"); |
} | } |
| |
//------------------------------------------------------------------------------ | //------------------------------------------------------------------------------ |
// | // |
// formatIReturnValueElement() |
// appendLocalClassPathElement() |
// | // |
// <!ELEMENT IRETURNVALUE (CLASSNAME*|INSTANCENAME*|VALUE*| |
// <!ELEMENT LOCALCLASSPATH (LOCALNAMESPACEPATH, CLASSNAME)> |
// VALUE.OBJECTWITHPATH*|VALUE.OBJECTWITHLOCALPATH*|VALUE.OBJECT*| |
|
// OBJECTPATH*|QUALIFIER.DECLARATION*|VALUE.ARRAY?|VALUE.REFERENCE?| |
|
// CLASS*|INSTANCE*|VALUE.NAMEDINSTANCE*)> |
|
// | // |
//------------------------------------------------------------------------------ | //------------------------------------------------------------------------------ |
| |
Array<Sint8> XmlWriter::formatIReturnValueElement( |
void XmlWriter::appendLocalClassPathElement( |
const Array<Sint8>& body) |
Buffer& out, |
|
const CIMObjectPath& classPath) |
{ | { |
Array<Sint8> out; |
out << STRLIT("<LOCALCLASSPATH>\n"); |
return out << "<IRETURNVALUE>\n" << body << "</IRETURNVALUE>\n"; |
appendLocalNameSpacePathElement(out, classPath.getNameSpace()); |
|
appendClassNameElement(out, classPath.getClassName()); |
|
out << STRLIT("</LOCALCLASSPATH>\n"); |
} | } |
| |
//------------------------------------------------------------------------------ | //------------------------------------------------------------------------------ |
// | // |
// formatIParamValueElement() |
// appendLocalInstancePathElement() |
// | // |
// <!ELEMENT IPARAMVALUE (VALUE|VALUE.ARRAY|VALUE.REFERENCE |
// <!ELEMENT LOCALINSTANCEPATH (LOCALNAMESPACEPATH, INSTANCENAME)> |
// |INSTANCENAME|CLASSNAME|QUALIFIER.DECLARATION |
|
// |CLASS|INSTANCE|VALUE.NAMEDINSTANCE)?> |
|
// <!ATTLIST IPARAMVALUE %CIMName;> |
|
// | // |
//------------------------------------------------------------------------------ | //------------------------------------------------------------------------------ |
| |
Array<Sint8>& XmlWriter::formatIParamValueElement( |
void XmlWriter::appendLocalInstancePathElement( |
Array<Sint8>& out, |
Buffer& out, |
const char* name, |
const CIMObjectPath& instancePath) |
const Array<Sint8>& body) |
|
{ | { |
out << "<IPARAMVALUE NAME=\"" << name << "\">\n"; |
out << STRLIT("<LOCALINSTANCEPATH>\n"); |
out << body; |
appendLocalNameSpacePathElement(out, instancePath.getNameSpace()); |
out << "</IPARAMVALUE>\n"; |
appendInstanceNameElement(out, instancePath); |
return out; |
out << STRLIT("</LOCALINSTANCEPATH>\n"); |
} | } |
| |
//------------------------------------------------------------------------------ | //------------------------------------------------------------------------------ |
// | // |
// formatErrorElement() |
// appendLocalObjectPathElement() |
|
// |
|
// If the reference refers to an instance, write a LOCALINSTANCEPATH; |
|
// otherwise write a LOCALCLASSPATH. |
// | // |
//------------------------------------------------------------------------------ | //------------------------------------------------------------------------------ |
| |
Array<Sint8> XmlWriter::formatErrorElement( |
void XmlWriter::appendLocalObjectPathElement( |
CIMStatusCode code, |
Buffer& out, |
const char* description) |
const CIMObjectPath& objectPath) |
{ | { |
Array<Sint8> out; |
// |
out << "<ERROR"; |
// ATTN-CAKG-P2-20020726: The following condition does not correctly |
out << " CODE=\"" << Uint32(code) << "\""; |
// distinguish instanceNames from classNames in every case |
out << " DESCRIPTION=\""; |
// The instanceName of a singleton instance of a keyless class has no |
appendSpecial(out, description); |
// key bindings |
out << "\"/>"; |
// |
return out; |
if (objectPath.getKeyBindings ().size () != 0) |
|
{ |
|
appendLocalInstancePathElement(out, objectPath); |
|
} |
|
else |
|
{ |
|
appendLocalClassPathElement(out, objectPath); |
|
} |
} | } |
| |
//------------------------------------------------------------------------------ | //------------------------------------------------------------------------------ |
// | // |
// appendBooleanParameter() |
// Helper functions for appendValueElement() |
// | // |
//------------------------------------------------------------------------------ | //------------------------------------------------------------------------------ |
| |
Array<Sint8>& XmlWriter::appendBooleanParameter( |
inline void _xmlWritter_appendValue(Buffer& out, Boolean x) |
Array<Sint8>& out, |
{ |
|
XmlWriter::append(out, x); |
|
} |
|
|
|
inline void _xmlWritter_appendValue(Buffer& out, Uint8 x) |
|
{ |
|
XmlWriter::append(out, Uint32(x)); |
|
} |
|
|
|
inline void _xmlWritter_appendValue(Buffer& out, Sint8 x) |
|
{ |
|
XmlWriter::append(out, Sint32(x)); |
|
} |
|
|
|
inline void _xmlWritter_appendValue(Buffer& out, Uint16 x) |
|
{ |
|
XmlWriter::append(out, Uint32(x)); |
|
} |
|
|
|
inline void _xmlWritter_appendValue(Buffer& out, Sint16 x) |
|
{ |
|
XmlWriter::append(out, Sint32(x)); |
|
} |
|
|
|
inline void _xmlWritter_appendValue(Buffer& out, Uint32 x) |
|
{ |
|
XmlWriter::append(out, x); |
|
} |
|
|
|
inline void _xmlWritter_appendValue(Buffer& out, Sint32 x) |
|
{ |
|
XmlWriter::append(out, x); |
|
} |
|
|
|
inline void _xmlWritter_appendValue(Buffer& out, Uint64 x) |
|
{ |
|
XmlWriter::append(out, x); |
|
} |
|
|
|
inline void _xmlWritter_appendValue(Buffer& out, Sint64 x) |
|
{ |
|
XmlWriter::append(out, x); |
|
} |
|
|
|
inline void _xmlWritter_appendValue(Buffer& out, Real32 x) |
|
{ |
|
XmlWriter::append(out, x); |
|
} |
|
|
|
inline void _xmlWritter_appendValue(Buffer& out, Real64 x) |
|
{ |
|
XmlWriter::append(out, x); |
|
} |
|
|
|
inline void _xmlWritter_appendValue(Buffer& out, const Char16& x) |
|
{ |
|
XmlWriter::appendSpecial(out, x); |
|
} |
|
|
|
inline void _xmlWritter_appendValue(Buffer& out, const String& x) |
|
{ |
|
XmlWriter::appendSpecial(out, x); |
|
} |
|
|
|
inline void _xmlWritter_appendValue(Buffer& out, const CIMDateTime& x) |
|
{ |
|
// It is not necessary to use XmlWriter::appendSpecial(), because |
|
// CIMDateTime values do not contain special characters. |
|
out << x.toString(); |
|
} |
|
|
|
inline void _xmlWritter_appendValue(Buffer& out, const CIMObjectPath& x) |
|
{ |
|
XmlWriter::appendValueReferenceElement(out, x, true); |
|
} |
|
|
|
inline void _xmlWritter_appendValue(Buffer& out, const CIMObject& x) |
|
{ |
|
String myStr = x.toString(); |
|
_xmlWritter_appendValue(out, myStr); |
|
} |
|
|
|
void _xmlWritter_appendValueArray( |
|
Buffer& out, const CIMObjectPath* p, Uint32 size) |
|
{ |
|
out << STRLIT("<VALUE.REFARRAY>\n"); |
|
while (size--) |
|
{ |
|
_xmlWritter_appendValue(out, *p++); |
|
} |
|
out << STRLIT("</VALUE.REFARRAY>\n"); |
|
} |
|
|
|
template<class T> |
|
void _xmlWritter_appendValueArray(Buffer& out, const T* p, Uint32 size) |
|
{ |
|
out << STRLIT("<VALUE.ARRAY>\n"); |
|
|
|
while (size--) |
|
{ |
|
out << STRLIT("<VALUE>"); |
|
_xmlWritter_appendValue(out, *p++); |
|
out << STRLIT("</VALUE>\n"); |
|
} |
|
|
|
out << STRLIT("</VALUE.ARRAY>\n"); |
|
} |
|
|
|
//------------------------------------------------------------------------------ |
|
// |
|
// appendValueElement() |
|
// |
|
// <!ELEMENT VALUE (#PCDATA)> |
|
// <!ELEMENT VALUE.ARRAY (VALUE*)> |
|
// <!ELEMENT VALUE.REFERENCE |
|
// (CLASSPATH|LOCALCLASSPATH|CLASSNAME|INSTANCEPATH|LOCALINSTANCEPATH| |
|
// INSTANCENAME)> |
|
// <!ELEMENT VALUE.REFARRAY (VALUE.REFERENCE*)> |
|
// |
|
//------------------------------------------------------------------------------ |
|
|
|
void XmlWriter::appendValueElement( |
|
Buffer& out, |
|
const CIMValue& value) |
|
{ |
|
if (value.isNull()) |
|
{ |
|
return; |
|
} |
|
if (value.isArray()) |
|
{ |
|
switch (value.getType()) |
|
{ |
|
case CIMTYPE_BOOLEAN: |
|
{ |
|
Array<Boolean> a; |
|
value.get(a); |
|
_xmlWritter_appendValueArray(out, a.getData(), a.size()); |
|
break; |
|
} |
|
|
|
case CIMTYPE_UINT8: |
|
{ |
|
Array<Uint8> a; |
|
value.get(a); |
|
_xmlWritter_appendValueArray(out, a.getData(), a.size()); |
|
break; |
|
} |
|
|
|
case CIMTYPE_SINT8: |
|
{ |
|
Array<Sint8> a; |
|
value.get(a); |
|
_xmlWritter_appendValueArray(out, a.getData(), a.size()); |
|
break; |
|
} |
|
|
|
case CIMTYPE_UINT16: |
|
{ |
|
Array<Uint16> a; |
|
value.get(a); |
|
_xmlWritter_appendValueArray(out, a.getData(), a.size()); |
|
break; |
|
} |
|
|
|
case CIMTYPE_SINT16: |
|
{ |
|
Array<Sint16> a; |
|
value.get(a); |
|
_xmlWritter_appendValueArray(out, a.getData(), a.size()); |
|
break; |
|
} |
|
|
|
case CIMTYPE_UINT32: |
|
{ |
|
Array<Uint32> a; |
|
value.get(a); |
|
_xmlWritter_appendValueArray(out, a.getData(), a.size()); |
|
break; |
|
} |
|
|
|
case CIMTYPE_SINT32: |
|
{ |
|
Array<Sint32> a; |
|
value.get(a); |
|
_xmlWritter_appendValueArray(out, a.getData(), a.size()); |
|
break; |
|
} |
|
|
|
case CIMTYPE_UINT64: |
|
{ |
|
Array<Uint64> a; |
|
value.get(a); |
|
_xmlWritter_appendValueArray(out, a.getData(), a.size()); |
|
break; |
|
} |
|
|
|
case CIMTYPE_SINT64: |
|
{ |
|
Array<Sint64> a; |
|
value.get(a); |
|
_xmlWritter_appendValueArray(out, a.getData(), a.size()); |
|
break; |
|
} |
|
|
|
case CIMTYPE_REAL32: |
|
{ |
|
Array<Real32> a; |
|
value.get(a); |
|
_xmlWritter_appendValueArray(out, a.getData(), a.size()); |
|
break; |
|
} |
|
|
|
case CIMTYPE_REAL64: |
|
{ |
|
Array<Real64> a; |
|
value.get(a); |
|
_xmlWritter_appendValueArray(out, a.getData(), a.size()); |
|
break; |
|
} |
|
|
|
case CIMTYPE_CHAR16: |
|
{ |
|
Array<Char16> a; |
|
value.get(a); |
|
_xmlWritter_appendValueArray(out, a.getData(), a.size()); |
|
break; |
|
} |
|
|
|
case CIMTYPE_STRING: |
|
{ |
|
const String* data; |
|
Uint32 size; |
|
value._get(data, size); |
|
_xmlWritter_appendValueArray(out, data, size); |
|
break; |
|
} |
|
|
|
case CIMTYPE_DATETIME: |
|
{ |
|
Array<CIMDateTime> a; |
|
value.get(a); |
|
_xmlWritter_appendValueArray(out, a.getData(), a.size()); |
|
break; |
|
} |
|
|
|
case CIMTYPE_REFERENCE: |
|
{ |
|
Array<CIMObjectPath> a; |
|
value.get(a); |
|
_xmlWritter_appendValueArray(out, a.getData(), a.size()); |
|
break; |
|
} |
|
|
|
case CIMTYPE_OBJECT: |
|
{ |
|
Array<CIMObject> a; |
|
value.get(a); |
|
_xmlWritter_appendValueArray(out, a.getData(), a.size()); |
|
break; |
|
} |
|
#ifdef PEGASUS_EMBEDDED_INSTANCE_SUPPORT |
|
case CIMTYPE_INSTANCE: |
|
{ |
|
Array<CIMInstance> a; |
|
value.get(a); |
|
_xmlWritter_appendValueArray(out, a.getData(), a.size()); |
|
break; |
|
} |
|
#endif // PEGASUS_EMBEDDED_INSTANCE_SUPPORT |
|
default: |
|
PEGASUS_ASSERT(false); |
|
} |
|
} |
|
else if (value.getType() == CIMTYPE_REFERENCE) |
|
{ |
|
// Has to be separate because it uses VALUE.REFERENCE tag |
|
CIMObjectPath v; |
|
value.get(v); |
|
_xmlWritter_appendValue(out, v); |
|
} |
|
else |
|
{ |
|
out << STRLIT("<VALUE>"); |
|
|
|
switch (value.getType()) |
|
{ |
|
case CIMTYPE_BOOLEAN: |
|
{ |
|
Boolean v; |
|
value.get(v); |
|
_xmlWritter_appendValue(out, v); |
|
break; |
|
} |
|
|
|
case CIMTYPE_UINT8: |
|
{ |
|
Uint8 v; |
|
value.get(v); |
|
_xmlWritter_appendValue(out, v); |
|
break; |
|
} |
|
|
|
case CIMTYPE_SINT8: |
|
{ |
|
Sint8 v; |
|
value.get(v); |
|
_xmlWritter_appendValue(out, v); |
|
break; |
|
} |
|
|
|
case CIMTYPE_UINT16: |
|
{ |
|
Uint16 v; |
|
value.get(v); |
|
_xmlWritter_appendValue(out, v); |
|
break; |
|
} |
|
|
|
case CIMTYPE_SINT16: |
|
{ |
|
Sint16 v; |
|
value.get(v); |
|
_xmlWritter_appendValue(out, v); |
|
break; |
|
} |
|
|
|
case CIMTYPE_UINT32: |
|
{ |
|
Uint32 v; |
|
value.get(v); |
|
_xmlWritter_appendValue(out, v); |
|
break; |
|
} |
|
|
|
case CIMTYPE_SINT32: |
|
{ |
|
Sint32 v; |
|
value.get(v); |
|
_xmlWritter_appendValue(out, v); |
|
break; |
|
} |
|
|
|
case CIMTYPE_UINT64: |
|
{ |
|
Uint64 v; |
|
value.get(v); |
|
_xmlWritter_appendValue(out, v); |
|
break; |
|
} |
|
|
|
case CIMTYPE_SINT64: |
|
{ |
|
Sint64 v; |
|
value.get(v); |
|
_xmlWritter_appendValue(out, v); |
|
break; |
|
} |
|
|
|
case CIMTYPE_REAL32: |
|
{ |
|
Real32 v; |
|
value.get(v); |
|
_xmlWritter_appendValue(out, v); |
|
break; |
|
} |
|
|
|
case CIMTYPE_REAL64: |
|
{ |
|
Real64 v; |
|
value.get(v); |
|
_xmlWritter_appendValue(out, v); |
|
break; |
|
} |
|
|
|
case CIMTYPE_CHAR16: |
|
{ |
|
Char16 v; |
|
value.get(v); |
|
_xmlWritter_appendValue(out, v); |
|
break; |
|
} |
|
|
|
case CIMTYPE_STRING: |
|
{ |
|
String v; |
|
value.get(v); |
|
_xmlWritter_appendValue(out, v); |
|
break; |
|
} |
|
|
|
case CIMTYPE_DATETIME: |
|
{ |
|
CIMDateTime v; |
|
value.get(v); |
|
_xmlWritter_appendValue(out, v); |
|
break; |
|
} |
|
|
|
case CIMTYPE_OBJECT: |
|
{ |
|
CIMObject v; |
|
value.get(v); |
|
_xmlWritter_appendValue(out, v); |
|
break; |
|
} |
|
#ifdef PEGASUS_EMBEDDED_INSTANCE_SUPPORT |
|
case CIMTYPE_INSTANCE: |
|
{ |
|
CIMInstance v; |
|
value.get(v); |
|
_xmlWritter_appendValue(out, v); |
|
break; |
|
} |
|
#endif // PEGASUS_EMBEDDED_INSTANCE_SUPPORT |
|
default: |
|
PEGASUS_ASSERT(false); |
|
} |
|
|
|
out << STRLIT("</VALUE>\n"); |
|
} |
|
} |
|
|
|
void XmlWriter::printValueElement( |
|
const CIMValue& value, |
|
PEGASUS_STD(ostream)& os) |
|
{ |
|
Buffer tmp; |
|
appendValueElement(tmp, value); |
|
tmp.append('\0'); |
|
os << tmp.getData() << PEGASUS_STD(endl); |
|
} |
|
|
|
//------------------------------------------------------------------------------ |
|
// |
|
// appendValueObjectWithPathElement() |
|
// |
|
// <!ELEMENT VALUE.OBJECTWITHPATH |
|
// ((CLASSPATH,CLASS)|(INSTANCEPATH,INSTANCE))> |
|
// |
|
//------------------------------------------------------------------------------ |
|
|
|
void XmlWriter::appendValueObjectWithPathElement( |
|
Buffer& out, |
|
const CIMObject& objectWithPath) |
|
{ |
|
out << STRLIT("<VALUE.OBJECTWITHPATH>\n"); |
|
|
|
appendValueReferenceElement(out, objectWithPath.getPath (), false); |
|
appendObjectElement(out, objectWithPath); |
|
|
|
out << STRLIT("</VALUE.OBJECTWITHPATH>\n"); |
|
} |
|
|
|
//------------------------------------------------------------------------------ |
|
// |
|
// appendValueReferenceElement() |
|
// |
|
// <!ELEMENT VALUE.REFERENCE |
|
// (CLASSPATH|LOCALCLASSPATH|CLASSNAME|INSTANCEPATH|LOCALINSTANCEPATH| |
|
// INSTANCENAME)> |
|
// |
|
//------------------------------------------------------------------------------ |
|
|
|
void XmlWriter::appendValueReferenceElement( |
|
Buffer& out, |
|
const CIMObjectPath& reference, |
|
Boolean putValueWrapper) |
|
{ |
|
if (putValueWrapper) |
|
out << STRLIT("<VALUE.REFERENCE>\n"); |
|
|
|
// See if it is a class or instance reference (instance references have |
|
// key-bindings; class references do not). |
|
// |
|
// ATTN-CAKG-P2-20020726: The following condition does not correctly |
|
// distinguish instanceNames from classNames in every case |
|
// The instanceName of a singleton instance of a keyless class has no |
|
// key bindings |
|
// |
|
|
|
const Array<CIMKeyBinding>& kbs = reference.getKeyBindings(); |
|
|
|
if (kbs.size()) |
|
{ |
|
if (reference.getHost().size()) |
|
{ |
|
appendInstancePathElement(out, reference); |
|
} |
|
else if (!reference.getNameSpace().isNull()) |
|
{ |
|
appendLocalInstancePathElement(out, reference); |
|
} |
|
else |
|
{ |
|
appendInstanceNameElement(out, reference); |
|
} |
|
} |
|
else |
|
{ |
|
if (reference.getHost().size()) |
|
{ |
|
appendClassPathElement(out, reference); |
|
} |
|
else if (!reference.getNameSpace().isNull()) |
|
{ |
|
appendLocalClassPathElement(out, reference); |
|
} |
|
else |
|
{ |
|
appendClassNameElement(out, reference.getClassName()); |
|
} |
|
} |
|
|
|
if (putValueWrapper) |
|
out << STRLIT("</VALUE.REFERENCE>\n"); |
|
} |
|
|
|
void XmlWriter::printValueReferenceElement( |
|
const CIMObjectPath& reference, |
|
PEGASUS_STD(ostream)& os) |
|
{ |
|
Buffer tmp; |
|
appendValueReferenceElement(tmp, reference, true); |
|
tmp.append('\0'); |
|
indentedPrint(os, tmp.getData()); |
|
} |
|
|
|
//------------------------------------------------------------------------------ |
|
// |
|
// appendValueNamedInstanceElement() |
|
// |
|
// <!ELEMENT VALUE.NAMEDINSTANCE (INSTANCENAME,INSTANCE)> |
|
// |
|
//------------------------------------------------------------------------------ |
|
|
|
void XmlWriter::appendValueNamedInstanceElement( |
|
Buffer& out, |
|
const CIMInstance& namedInstance) |
|
{ |
|
out << STRLIT("<VALUE.NAMEDINSTANCE>\n"); |
|
|
|
appendInstanceNameElement(out, namedInstance.getPath ()); |
|
appendInstanceElement(out, namedInstance); |
|
|
|
out << STRLIT("</VALUE.NAMEDINSTANCE>\n"); |
|
} |
|
|
|
//------------------------------------------------------------------------------ |
|
// |
|
// appendClassElement() |
|
// |
|
// <!ELEMENT CLASS |
|
// (QUALIFIER*,(PROPERTY|PROPERTY.ARRAY|PROPERTY.REFERENCE)*,METHOD*)> |
|
// <!ATTLIST CLASS |
|
// %CIMName; |
|
// %SuperClass;> |
|
// |
|
//------------------------------------------------------------------------------ |
|
|
|
void XmlWriter::appendClassElement( |
|
Buffer& out, |
|
const CIMConstClass& cimclass) |
|
{ |
|
cimclass._checkRep(); |
|
cimclass._rep->toXml(out); |
|
} |
|
|
|
void XmlWriter::printClassElement( |
|
const CIMConstClass& cimclass, |
|
PEGASUS_STD(ostream)& os) |
|
{ |
|
Buffer tmp; |
|
appendClassElement(tmp, cimclass); |
|
tmp.append('\0'); |
|
indentedPrint(os, tmp.getData(), 4); |
|
} |
|
|
|
//------------------------------------------------------------------------------ |
|
// |
|
// appendInstanceElement() |
|
// |
|
// <!ELEMENT INSTANCE |
|
// (QUALIFIER*,(PROPERTY|PROPERTY.ARRAY|PROPERTY.REFERENCE)*)> |
|
// <!ATTLIST INSTANCE |
|
// %ClassName;> |
|
// |
|
//------------------------------------------------------------------------------ |
|
|
|
void XmlWriter::appendInstanceElement( |
|
Buffer& out, |
|
const CIMConstInstance& instance) |
|
{ |
|
instance._checkRep(); |
|
instance._rep->toXml(out); |
|
} |
|
|
|
void XmlWriter::printInstanceElement( |
|
const CIMConstInstance& instance, |
|
PEGASUS_STD(ostream)& os) |
|
{ |
|
Buffer tmp; |
|
appendInstanceElement(tmp, instance); |
|
tmp.append('\0'); |
|
os << tmp.getData() << PEGASUS_STD(endl); |
|
} |
|
|
|
//------------------------------------------------------------------------------ |
|
// |
|
// appendObjectElement() |
|
// |
|
// May refer to a CLASS or an INSTANCE |
|
// |
|
//------------------------------------------------------------------------------ |
|
|
|
void XmlWriter::appendObjectElement( |
|
Buffer& out, |
|
const CIMConstObject& object) |
|
{ |
|
if (object.isClass()) |
|
{ |
|
CIMConstClass c(object); |
|
appendClassElement(out, c); |
|
} |
|
else if (object.isInstance()) |
|
{ |
|
CIMConstInstance i(object); |
|
appendInstanceElement(out, i); |
|
} |
|
// else PEGASUS_ASSERT(0); |
|
} |
|
|
|
//------------------------------------------------------------------------------ |
|
// |
|
// appendPropertyElement() |
|
// |
|
// <!ELEMENT PROPERTY (QUALIFIER*,VALUE?)> |
|
// <!ATTLIST PROPERTY |
|
// %CIMName; |
|
// %CIMType; #REQUIRED |
|
// %ClassOrigin; |
|
// %Propagated;> |
|
// |
|
// <!ELEMENT PROPERTY.ARRAY (QUALIFIER*,VALUE.ARRAY?)> |
|
// <!ATTLIST PROPERTY.ARRAY |
|
// %CIMName; |
|
// %CIMType; #REQUIRED |
|
// %ArraySize; |
|
// %ClassOrigin; |
|
// %Propagated;> |
|
// |
|
// <!ELEMENT PROPERTY.REFERENCE (QUALIFIER*,VALUE.REFERENCE?)> |
|
// <!ATTLIST PROPERTY.REFERENCE |
|
// %CIMName; |
|
// %ReferenceClass; |
|
// %ClassOrigin; |
|
// %Propagated;> |
|
// |
|
//------------------------------------------------------------------------------ |
|
|
|
void XmlWriter::appendPropertyElement( |
|
Buffer& out, |
|
const CIMConstProperty& property) |
|
{ |
|
property._checkRep(); |
|
property._rep->toXml(out); |
|
} |
|
|
|
void XmlWriter::printPropertyElement( |
|
const CIMConstProperty& property, |
|
PEGASUS_STD(ostream)& os) |
|
{ |
|
Buffer tmp; |
|
appendPropertyElement(tmp, property); |
|
tmp.append('\0'); |
|
os << tmp.getData() << PEGASUS_STD(endl); |
|
} |
|
|
|
//------------------------------------------------------------------------------ |
|
// |
|
// appendMethodElement() |
|
// |
|
// <!ELEMENT METHOD (QUALIFIER*, |
|
// (PARAMETER|PARAMETER.REFERENCE|PARAMETER.ARRAY|PARAMETER.REFARRAY)*)> |
|
// <!ATTLIST METHOD |
|
// %CIMName; |
|
// %CIMType; #IMPLIED |
|
// %ClassOrigin; |
|
// %Propagated;> |
|
// |
|
//------------------------------------------------------------------------------ |
|
|
|
void XmlWriter::appendMethodElement( |
|
Buffer& out, |
|
const CIMConstMethod& method) |
|
{ |
|
method._checkRep(); |
|
method._rep->toXml(out); |
|
} |
|
|
|
void XmlWriter::printMethodElement( |
|
const CIMConstMethod& method, |
|
PEGASUS_STD(ostream)& os) |
|
{ |
|
Buffer tmp; |
|
appendMethodElement(tmp, method); |
|
tmp.append('\0'); |
|
os << tmp.getData() << PEGASUS_STD(endl); |
|
} |
|
|
|
//------------------------------------------------------------------------------ |
|
// |
|
// appendParameterElement() |
|
// |
|
// <!ELEMENT PARAMETER (QUALIFIER*)> |
|
// <!ATTLIST PARAMETER |
|
// %CIMName; |
|
// %CIMType; #REQUIRED> |
|
// |
|
// <!ELEMENT PARAMETER.REFERENCE (QUALIFIER*)> |
|
// <!ATTLIST PARAMETER.REFERENCE |
|
// %CIMName; |
|
// %ReferenceClass;> |
|
// |
|
// <!ELEMENT PARAMETER.ARRAY (QUALIFIER*)> |
|
// <!ATTLIST PARAMETER.ARRAY |
|
// %CIMName; |
|
// %CIMType; #REQUIRED |
|
// %ArraySize;> |
|
// |
|
// <!ELEMENT PARAMETER.REFARRAY (QUALIFIER*)> |
|
// <!ATTLIST PARAMETER.REFARRAY |
|
// %CIMName; |
|
// %ReferenceClass; |
|
// %ArraySize;> |
|
// |
|
//------------------------------------------------------------------------------ |
|
|
|
void XmlWriter::appendParameterElement( |
|
Buffer& out, |
|
const CIMConstParameter& parameter) |
|
{ |
|
parameter._checkRep(); |
|
parameter._rep->toXml(out); |
|
} |
|
|
|
void XmlWriter::printParameterElement( |
|
const CIMConstParameter& parameter, |
|
PEGASUS_STD(ostream)& os) |
|
{ |
|
Buffer tmp; |
|
appendParameterElement(tmp, parameter); |
|
tmp.append('\0'); |
|
os << tmp.getData() << PEGASUS_STD(endl); |
|
} |
|
|
|
//------------------------------------------------------------------------------ |
|
// |
|
// appendParamValueElement() |
|
// |
|
// <!ELEMENT PARAMVALUE (VALUE|VALUE.REFERENCE|VALUE.ARRAY|VALUE.REFARRAY)?> |
|
// <!ATTLIST PARAMVALUE |
|
// %CIMName;> |
|
// |
|
//------------------------------------------------------------------------------ |
|
|
|
void XmlWriter::appendParamValueElement( |
|
Buffer& out, |
|
const CIMParamValue& paramValue) |
|
{ |
|
paramValue._checkRep(); |
|
paramValue._rep->toXml(out); |
|
} |
|
|
|
void XmlWriter::printParamValueElement( |
|
const CIMParamValue& paramValue, |
|
PEGASUS_STD(ostream)& os) |
|
{ |
|
Buffer tmp; |
|
appendParamValueElement(tmp, paramValue); |
|
tmp.append('\0'); |
|
os << tmp.getData() << PEGASUS_STD(endl); |
|
} |
|
|
|
//------------------------------------------------------------------------------ |
|
// |
|
// appendQualifierElement() |
|
// |
|
// <!ELEMENT QUALIFIER (VALUE|VALUE.ARRAY)> |
|
// <!ATTLIST QUALIFIER |
|
// %CIMName; |
|
// %CIMType; #REQUIRED |
|
// %Propagated; |
|
// %QualifierFlavor;> |
|
// |
|
//------------------------------------------------------------------------------ |
|
|
|
void XmlWriter::appendQualifierElement( |
|
Buffer& out, |
|
const CIMConstQualifier& qualifier) |
|
{ |
|
qualifier._checkRep(); |
|
qualifier._rep->toXml(out); |
|
} |
|
|
|
void XmlWriter::printQualifierElement( |
|
const CIMConstQualifier& qualifier, |
|
PEGASUS_STD(ostream)& os) |
|
{ |
|
Buffer tmp; |
|
appendQualifierElement(tmp, qualifier); |
|
tmp.append('\0'); |
|
os << tmp.getData() << PEGASUS_STD(endl); |
|
} |
|
|
|
//------------------------------------------------------------------------------ |
|
// |
|
// appendQualifierDeclElement() |
|
// |
|
// <!ELEMENT QUALIFIER.DECLARATION (SCOPE?,(VALUE|VALUE.ARRAY)?)> |
|
// <!ATTLIST QUALIFIER.DECLARATION |
|
// %CIMName; |
|
// %CIMType; #REQUIRED |
|
// ISARRAY (true|false) #IMPLIED |
|
// %ArraySize; |
|
// %QualifierFlavor;> |
|
// |
|
//------------------------------------------------------------------------------ |
|
|
|
void XmlWriter::appendQualifierDeclElement( |
|
Buffer& out, |
|
const CIMConstQualifierDecl& qualifierDecl) |
|
{ |
|
qualifierDecl._checkRep(); |
|
qualifierDecl._rep->toXml(out); |
|
} |
|
|
|
void XmlWriter::printQualifierDeclElement( |
|
const CIMConstQualifierDecl& qualifierDecl, |
|
PEGASUS_STD(ostream)& os) |
|
{ |
|
Buffer tmp; |
|
appendQualifierDeclElement(tmp, qualifierDecl); |
|
tmp.append('\0'); |
|
os << tmp.getData() << PEGASUS_STD(endl); |
|
} |
|
|
|
//------------------------------------------------------------------------------ |
|
// |
|
// appendQualifierFlavorEntity() |
|
// |
|
// <!ENTITY % QualifierFlavor "OVERRIDABLE (true|false) 'true' |
|
// TOSUBCLASS (true|false) 'true' |
|
// TOINSTANCE (true|false) 'false' |
|
// TRANSLATABLE (true|false) 'false'"> |
|
// |
|
//------------------------------------------------------------------------------ |
|
|
|
void XmlWriter::appendQualifierFlavorEntity( |
|
Buffer& out, |
|
const CIMFlavor & flavor) |
|
{ |
|
if (!(flavor.hasFlavor (CIMFlavor::OVERRIDABLE))) |
|
out << STRLIT(" OVERRIDABLE=\"false\""); |
|
|
|
if (!(flavor.hasFlavor (CIMFlavor::TOSUBCLASS))) |
|
out << STRLIT(" TOSUBCLASS=\"false\""); |
|
|
|
if (flavor.hasFlavor (CIMFlavor::TOINSTANCE)) |
|
out << STRLIT(" TOINSTANCE=\"true\""); |
|
|
|
if (flavor.hasFlavor (CIMFlavor::TRANSLATABLE)) |
|
out << STRLIT(" TRANSLATABLE=\"true\""); |
|
} |
|
|
|
//------------------------------------------------------------------------------ |
|
// |
|
// appendScopeElement() |
|
// |
|
// <!ELEMENT SCOPE EMPTY> |
|
// <!ATTLIST SCOPE |
|
// CLASS (true|false) 'false' |
|
// ASSOCIATION (true|false) 'false' |
|
// REFERENCE (true|false) 'false' |
|
// PROPERTY (true|false) 'false' |
|
// METHOD (true|false) 'false' |
|
// PARAMETER (true|false) 'false' |
|
// INDICATION (true|false) 'false'> |
|
// |
|
//------------------------------------------------------------------------------ |
|
|
|
void XmlWriter::appendScopeElement( |
|
Buffer& out, |
|
const CIMScope & scope) |
|
{ |
|
if (!(scope.equal (CIMScope ()))) |
|
{ |
|
out << STRLIT("<SCOPE"); |
|
|
|
if (scope.hasScope (CIMScope::CLASS)) |
|
out << STRLIT(" CLASS=\"true\""); |
|
|
|
if (scope.hasScope (CIMScope::ASSOCIATION)) |
|
out << STRLIT(" ASSOCIATION=\"true\""); |
|
|
|
if (scope.hasScope (CIMScope::REFERENCE)) |
|
out << STRLIT(" REFERENCE=\"true\""); |
|
|
|
if (scope.hasScope (CIMScope::PROPERTY)) |
|
out << STRLIT(" PROPERTY=\"true\""); |
|
|
|
if (scope.hasScope (CIMScope::METHOD)) |
|
out << STRLIT(" METHOD=\"true\""); |
|
|
|
if (scope.hasScope (CIMScope::PARAMETER)) |
|
out << STRLIT(" PARAMETER=\"true\""); |
|
|
|
if (scope.hasScope (CIMScope::INDICATION)) |
|
out << STRLIT(" INDICATION=\"true\""); |
|
|
|
out << STRLIT("/>"); |
|
} |
|
} |
|
|
|
// l10n - added content language and accept language support to |
|
// the header methods below |
|
|
|
//------------------------------------------------------------------------------ |
|
// |
|
// appendMethodCallHeader() |
|
// |
|
// Build HTTP method call request header. |
|
// |
|
//------------------------------------------------------------------------------ |
|
|
|
void XmlWriter::appendMethodCallHeader( |
|
Buffer& out, |
|
const char* host, |
|
const CIMName& cimMethod, |
|
const String& cimObject, |
|
const String& authenticationHeader, |
|
HttpMethod httpMethod, |
|
const AcceptLanguageList& acceptLanguages, |
|
const ContentLanguageList& contentLanguages, |
|
Uint32 contentLength) |
|
{ |
|
char nn[] = { '0' + (rand() % 10), '0' + (rand() % 10), '\0' }; |
|
|
|
// ATTN: KS 20020926 - Temporary change to issue only POST. This may |
|
// be changed in the DMTF CIM Operations standard in the future. |
|
// If we kept M-Post we would have to retry with Post. Does not |
|
// do that in client today. Permanent change is to retry until spec |
|
// updated. This change is temp to finish tests or until the retry |
|
// installed. Required because of change to wbemservices cimom |
|
if (httpMethod == HTTP_METHOD_M_POST) |
|
{ |
|
out << STRLIT("M-POST /cimom HTTP/1.1\r\n"); |
|
} |
|
else |
|
{ |
|
out << STRLIT("POST /cimom HTTP/1.1\r\n"); |
|
} |
|
out << STRLIT("HOST: ") << host << STRLIT("\r\n"); |
|
out << STRLIT("Content-Type: application/xml; charset=\"utf-8\"\r\n"); |
|
OUTPUT_CONTENTLENGTH; |
|
if (acceptLanguages.size() > 0) |
|
{ |
|
out << STRLIT("Accept-Language: ") << acceptLanguages << STRLIT("\r\n"); |
|
} |
|
if (contentLanguages.size() > 0) |
|
{ |
|
out << STRLIT("Content-Language: ") << contentLanguages << STRLIT("\r\n"); |
|
} |
|
|
|
#ifdef PEGASUS_DEBUG |
|
// backdoor environment variable to turn OFF client requesting transfer |
|
// encoding. The default is on. to turn off, set this variable to zero. |
|
// This should be removed when stable. This should only be turned off in |
|
// a debugging/testing environment. |
|
|
|
static const char *clientTransferEncodingOff = |
|
getenv("PEGASUS_HTTP_TRANSFER_ENCODING_REQUEST"); |
|
if (!clientTransferEncodingOff || *clientTransferEncodingOff != '0') |
|
#endif |
|
|
|
out << STRLIT("TE: chunked, trailers\r\n"); |
|
|
|
if (httpMethod == HTTP_METHOD_M_POST) |
|
{ |
|
out << STRLIT("Man: http://www.dmtf.org/cim/mapping/http/v1.0; ns="); |
|
out << nn << STRLIT("\r\n"); |
|
out << nn << STRLIT("-CIMOperation: MethodCall\r\n"); |
|
out << nn << STRLIT("-CIMMethod: ") |
|
<< encodeURICharacters(cimMethod.getString()) << STRLIT("\r\n"); |
|
out << nn << STRLIT("-CIMObject: ") << encodeURICharacters(cimObject) |
|
<< STRLIT("\r\n"); |
|
} |
|
else |
|
{ |
|
out << STRLIT("CIMOperation: MethodCall\r\n"); |
|
out << STRLIT("CIMMethod: ") << encodeURICharacters(cimMethod.getString()) |
|
<< STRLIT("\r\n"); |
|
out << STRLIT("CIMObject: ") << encodeURICharacters(cimObject) |
|
<< STRLIT("\r\n"); |
|
} |
|
|
|
if (authenticationHeader.size()) |
|
{ |
|
out << authenticationHeader << STRLIT("\r\n"); |
|
} |
|
|
|
out << STRLIT("\r\n"); |
|
} |
|
|
|
|
|
void XmlWriter::appendMethodResponseHeader( |
|
Buffer& out, |
|
HttpMethod httpMethod, |
|
const ContentLanguageList& contentLanguages, |
|
Uint32 contentLength, |
|
Uint64 serverResponseTime) |
|
{ |
|
char nn[] = { '0' + (rand() % 10), '0' + (rand() % 10), '\0' }; |
|
out << STRLIT("HTTP/1.1 " HTTP_STATUS_OK "\r\n"); |
|
|
|
#ifndef PEGASUS_DISABLE_PERFINST |
|
if (StatisticalData::current()->copyGSD) |
|
{ |
|
out << STRLIT("WBEMServerResponseTime: ") << |
|
CIMValue(serverResponseTime).toString() << STRLIT("\r\n"); |
|
} |
|
#endif |
|
|
|
out << STRLIT("Content-Type: application/xml; charset=\"utf-8\"\r\n"); |
|
OUTPUT_CONTENTLENGTH; |
|
|
|
if (contentLanguages.size() > 0) |
|
{ |
|
out << STRLIT("Content-Language: ") << contentLanguages << STRLIT("\r\n"); |
|
} |
|
if (httpMethod == HTTP_METHOD_M_POST) |
|
{ |
|
out << STRLIT("Ext:\r\n"); |
|
out << STRLIT("Cache-Control: no-cache\r\n"); |
|
out << STRLIT("Man: http://www.dmtf.org/cim/mapping/http/v1.0; ns="); |
|
out << nn << STRLIT("\r\n"); |
|
out << nn << STRLIT("-CIMOperation: MethodResponse\r\n\r\n"); |
|
} |
|
else |
|
{ |
|
out << STRLIT("CIMOperation: MethodResponse\r\n\r\n"); |
|
} |
|
} |
|
|
|
|
|
//------------------------------------------------------------------------------ |
|
// |
|
// appendHttpErrorResponseHeader() |
|
// |
|
// Build HTTP error response header. |
|
// |
|
// Returns error response message in the following format: |
|
// |
|
// HTTP/1.1 400 Bad Request (using specified status code) |
|
// CIMError: <error type> (if specified by caller) |
|
// PGErrorDetail: <error text> (if specified by caller) |
|
// |
|
//------------------------------------------------------------------------------ |
|
|
|
void XmlWriter::appendHttpErrorResponseHeader( |
|
Buffer& out, |
|
const String& status, |
|
const String& cimError, |
|
const String& errorDetail) |
|
{ |
|
out << STRLIT("HTTP/1.1 ") << status << STRLIT("\r\n"); |
|
if (cimError != String::EMPTY) |
|
{ |
|
out << STRLIT("CIMError: ") << cimError << STRLIT("\r\n"); |
|
} |
|
if (errorDetail != String::EMPTY) |
|
{ |
|
out << STRLIT(PEGASUS_HTTPHEADERTAG_ERRORDETAIL ": ") |
|
<< encodeURICharacters(errorDetail) << STRLIT("\r\n"); |
|
} |
|
out << STRLIT("\r\n"); |
|
} |
|
|
|
//------------------------------------------------------------------------------ |
|
// |
|
// appendUnauthorizedResponseHeader() |
|
// |
|
// Build HTTP authentication response header for unauthorized requests. |
|
// |
|
// Returns unauthorized message in the following format: |
|
// |
|
// HTTP/1.1 401 Unauthorized |
|
// WWW-Authenticate: Basic "hostname:80" |
|
// <HTML><HEAD> |
|
// <TITLE>401 Unauthorized</TITLE> |
|
// </HEAD><BODY BGCOLOR="#99cc99"> |
|
// <H2>TEST401 Unauthorized</H2> |
|
// <HR> |
|
// </BODY></HTML> |
|
// |
|
//------------------------------------------------------------------------------ |
|
|
|
void XmlWriter::appendUnauthorizedResponseHeader( |
|
Buffer& out, |
|
const String& content) |
|
{ |
|
out << STRLIT("HTTP/1.1 " HTTP_STATUS_UNAUTHORIZED "\r\n"); |
|
out << content << STRLIT("\r\n"); |
|
out << STRLIT("\r\n"); |
|
|
|
//ATTN: We may need to include the following line, so that the browsers |
|
// can display the error message. |
|
// out << "<HTML><HEAD>\r\n"; |
|
// out << "<TITLE>" << "401 Unauthorized" << "</TITLE>\r\n"; |
|
// out << "</HEAD><BODY BGCOLOR=\"#99cc99\">\r\n"; |
|
// out << "<H2>TEST" << "401 Unauthorized" << "</H2>\r\n"; |
|
// out << "<HR>\r\n"; |
|
// out << "</BODY></HTML>\r\n"; |
|
} |
|
|
|
#ifdef PEGASUS_KERBEROS_AUTHENTICATION |
|
//------------------------------------------------------------------------------ |
|
// |
|
// appendOKResponseHeader() |
|
// |
|
// Build HTTP authentication response header for unauthorized requests. |
|
// |
|
// Returns OK message in the following format: |
|
// |
|
// HTTP/1.1 200 OK |
|
// Content-Length: 0 |
|
// WWW-Authenticate: Negotiate "token" |
|
// <HTML><HEAD> |
|
// <TITLE>200 OK</TITLE> |
|
// </HEAD><BODY BGCOLOR="#99cc99"> |
|
// <H2>TEST200 OK</H2> |
|
// <HR> |
|
// </BODY></HTML> |
|
// |
|
//------------------------------------------------------------------------------ |
|
|
|
void XmlWriter::appendOKResponseHeader( |
|
Buffer& out, |
|
const String& content) |
|
{ |
|
out << STRLIT("HTTP/1.1 " HTTP_STATUS_OK "\r\n"); |
|
// Content-Length header needs to be added because 200 OK record |
|
// is usually intended to have content. But, for Kerberos this |
|
// may not always be the case so we need to indicate that there |
|
// is no content |
|
Uint32 contentLength = 0; |
|
OUTPUT_CONTENTLENGTH; |
|
out << content << STRLIT("\r\n"); |
|
out << STRLIT("\r\n"); |
|
|
|
//ATTN: We may need to include the following line, so that the browsers |
|
// can display the error message. |
|
// out << "<HTML><HEAD>\r\n"; |
|
// out << "<TITLE>" << "200 OK" << "</TITLE>\r\n"; |
|
// out << "</HEAD><BODY BGCOLOR=\"#99cc99\">\r\n"; |
|
// out << "<H2>TEST" << "200 OK" << "</H2>\r\n"; |
|
// out << "<HR>\r\n"; |
|
// out << "</BODY></HTML>\r\n"; |
|
} |
|
#endif |
|
|
|
//------------------------------------------------------------------------------ |
|
// |
|
// _appendMessageElementBegin() |
|
// _appendMessageElementEnd() |
|
// |
|
// <!ELEMENT MESSAGE (SIMPLEREQ|MULTIREQ|SIMPLERSP|MULTIRSP)> |
|
// <!ATTLIST MESSAGE |
|
// ID CDATA #REQUIRED |
|
// PROTOCOLVERSION CDATA #REQUIRED> |
|
// |
|
//------------------------------------------------------------------------------ |
|
|
|
void XmlWriter::_appendMessageElementBegin( |
|
Buffer& out, |
|
const String& messageId) |
|
{ |
|
out << STRLIT("<?xml version=\"1.0\" encoding=\"utf-8\" ?>\n"); |
|
out << STRLIT("<CIM CIMVERSION=\"2.0\" DTDVERSION=\"2.0\">\n"); |
|
out << STRLIT("<MESSAGE ID=\"") << messageId; |
|
out << STRLIT("\" PROTOCOLVERSION=\"1.0\">\n"); |
|
} |
|
|
|
void XmlWriter::_appendMessageElementEnd( |
|
Buffer& out) |
|
{ |
|
out << STRLIT("</MESSAGE>\n"); |
|
out << STRLIT("</CIM>\n"); |
|
} |
|
|
|
//------------------------------------------------------------------------------ |
|
// |
|
// _appendSimpleReqElementBegin() |
|
// _appendSimpleReqElementEnd() |
|
// |
|
// <!ELEMENT SIMPLEREQ (IMETHODCALL|METHODCALL)> |
|
// |
|
//------------------------------------------------------------------------------ |
|
|
|
void XmlWriter::_appendSimpleReqElementBegin( |
|
Buffer& out) |
|
{ |
|
out << STRLIT("<SIMPLEREQ>\n"); |
|
} |
|
|
|
void XmlWriter::_appendSimpleReqElementEnd( |
|
Buffer& out) |
|
{ |
|
out << STRLIT("</SIMPLEREQ>\n"); |
|
} |
|
|
|
//------------------------------------------------------------------------------ |
|
// |
|
// _appendMethodCallElementBegin() |
|
// _appendMethodCallElementEnd() |
|
// |
|
// <!ELEMENT METHODCALL ((LOCALCLASSPATH|LOCALINSTANCEPATH),PARAMVALUE*)> |
|
// <!ATTLIST METHODCALL %CIMName;> |
|
// |
|
//------------------------------------------------------------------------------ |
|
|
|
void XmlWriter::_appendMethodCallElementBegin( |
|
Buffer& out, |
|
const CIMName& name) |
|
{ |
|
out << STRLIT("<METHODCALL NAME=\"") << name << STRLIT("\">\n"); |
|
} |
|
|
|
void XmlWriter::_appendMethodCallElementEnd( |
|
Buffer& out) |
|
{ |
|
out << STRLIT("</METHODCALL>\n"); |
|
} |
|
|
|
//------------------------------------------------------------------------------ |
|
// |
|
// _appendIMethodCallElementBegin() |
|
// _appendIMethodCallElementEnd() |
|
// |
|
// <!ELEMENT IMETHODCALL (LOCALNAMESPACEPATH,IPARAMVALUE*)> |
|
// <!ATTLIST IMETHODCALL %CIMName;> |
|
// |
|
//------------------------------------------------------------------------------ |
|
|
|
void XmlWriter::_appendIMethodCallElementBegin( |
|
Buffer& out, |
|
const CIMName& name) |
|
{ |
|
out << STRLIT("<IMETHODCALL NAME=\"") << name << STRLIT("\">\n"); |
|
} |
|
|
|
void XmlWriter::_appendIMethodCallElementEnd( |
|
Buffer& out) |
|
{ |
|
out << STRLIT("</IMETHODCALL>\n"); |
|
} |
|
|
|
//------------------------------------------------------------------------------ |
|
// |
|
// _appendIParamValueElementBegin() |
|
// _appendIParamValueElementEnd() |
|
// |
|
// <!ELEMENT IPARAMVALUE (VALUE|VALUE.ARRAY|VALUE.REFERENCE |
|
// |INSTANCENAME|CLASSNAME|QUALIFIER.DECLARATION |
|
// |CLASS|INSTANCE|VALUE.NAMEDINSTANCE)?> |
|
// <!ATTLIST IPARAMVALUE %CIMName;> |
|
// |
|
//------------------------------------------------------------------------------ |
|
|
|
void XmlWriter::_appendIParamValueElementBegin( |
|
Buffer& out, |
|
const char* name) |
|
{ |
|
out << STRLIT("<IPARAMVALUE NAME=\"") << name << STRLIT("\">\n"); |
|
} |
|
|
|
void XmlWriter::_appendIParamValueElementEnd( |
|
Buffer& out) |
|
{ |
|
out << STRLIT("</IPARAMVALUE>\n"); |
|
} |
|
|
|
//------------------------------------------------------------------------------ |
|
// |
|
// _appendSimpleRspElementBegin() |
|
// _appendSimpleRspElementEnd() |
|
// |
|
// <!ELEMENT SIMPLERSP (METHODRESPONSE|IMETHODRESPONSE)> |
|
// |
|
//------------------------------------------------------------------------------ |
|
|
|
void XmlWriter::_appendSimpleRspElementBegin( |
|
Buffer& out) |
|
{ |
|
out << STRLIT("<SIMPLERSP>\n"); |
|
} |
|
|
|
void XmlWriter::_appendSimpleRspElementEnd( |
|
Buffer& out) |
|
{ |
|
out << STRLIT("</SIMPLERSP>\n"); |
|
} |
|
|
|
//------------------------------------------------------------------------------ |
|
// |
|
// _appendMethodResponseElementBegin() |
|
// _appendMethodResponseElementEnd() |
|
// |
|
// <!ELEMENT METHODRESPONSE (ERROR|IRETURNVALUE?)> |
|
// <!ATTLIST METHODRESPONSE %CIMName;> |
|
// |
|
//------------------------------------------------------------------------------ |
|
|
|
void XmlWriter::_appendMethodResponseElementBegin( |
|
Buffer& out, |
|
const CIMName& name) |
|
{ |
|
out << STRLIT("<METHODRESPONSE NAME=\"") << name << STRLIT("\">\n"); |
|
} |
|
|
|
void XmlWriter::_appendMethodResponseElementEnd( |
|
Buffer& out) |
|
{ |
|
out << STRLIT("</METHODRESPONSE>\n"); |
|
} |
|
|
|
//------------------------------------------------------------------------------ |
|
// |
|
// _appendIMethodResponseElementBegin() |
|
// _appendIMethodResponseElementEnd() |
|
// |
|
// <!ELEMENT IMETHODRESPONSE (ERROR|IRETURNVALUE?)> |
|
// <!ATTLIST IMETHODRESPONSE %CIMName;> |
|
// |
|
//------------------------------------------------------------------------------ |
|
|
|
void XmlWriter::_appendIMethodResponseElementBegin( |
|
Buffer& out, |
|
const CIMName& name) |
|
{ |
|
out << STRLIT("<IMETHODRESPONSE NAME=\"") << name << STRLIT("\">\n"); |
|
} |
|
|
|
void XmlWriter::_appendIMethodResponseElementEnd( |
|
Buffer& out) |
|
{ |
|
out << STRLIT("</IMETHODRESPONSE>\n"); |
|
} |
|
|
|
//------------------------------------------------------------------------------ |
|
// |
|
// _appendErrorElement() |
|
// |
|
//------------------------------------------------------------------------------ |
|
|
|
void XmlWriter::_appendErrorElement( |
|
Buffer& out, |
|
const CIMException& cimException) |
|
{ |
|
Tracer::traceCIMException(TRC_XML_WRITER, Tracer::LEVEL2, cimException); |
|
|
|
out << STRLIT("<ERROR"); |
|
out << STRLIT(" CODE=\"") << Uint32(cimException.getCode()); |
|
out.append('"'); |
|
String description = TraceableCIMException(cimException).getDescription(); |
|
if (description != String::EMPTY) |
|
{ |
|
out << STRLIT(" DESCRIPTION=\""); |
|
appendSpecial(out, description); |
|
out.append('"'); |
|
} |
|
out << STRLIT("/>"); |
|
} |
|
|
|
//------------------------------------------------------------------------------ |
|
// |
|
// appendReturnValueElement() |
|
// |
|
// <!ELEMENT RETURNVALUE (VALUE|VALUE.REFERENCE)> |
|
// <!ATTLIST RETURNVALUE |
|
// %EmbeddedObject; #IMPLIED |
|
// %ParamType;> |
|
// |
|
//------------------------------------------------------------------------------ |
|
|
|
void XmlWriter::appendReturnValueElement( |
|
Buffer& out, |
|
const CIMValue& value) |
|
{ |
|
out << STRLIT("<RETURNVALUE"); |
|
|
|
CIMType type = value.getType(); |
|
// If the property type is CIMObject, then |
|
// encode the property in CIM-XML as a string with the EMBEDDEDOBJECT attribute |
|
// (there is not currently a CIM-XML "object" datatype) |
|
// else |
|
// output the real type |
|
if (type == CIMTYPE_OBJECT) |
|
{ |
|
out << STRLIT(" PARAMTYPE=\"string\""); |
|
out << STRLIT(" EMBEDDEDOBJECT=\"object\""); |
|
} |
|
#ifdef PEGASUS_EMBEDDED_INSTANCE_SUPPORT |
|
else if (type == CIMTYPE_INSTANCE) |
|
{ |
|
out << STRLIT(" PARAMTYPE=\"string\""); |
|
out << STRLIT(" EMBEDDEDOBJECT=\"instance\""); |
|
} |
|
#endif // PEGASUS_EMBEDDED_INSTANCE_SUPPORT |
|
else |
|
{ |
|
out << STRLIT(" PARAMTYPE=\"") << cimTypeToString (type); |
|
out.append('"'); |
|
} |
|
|
|
out << STRLIT(">\n"); |
|
|
|
// Add value. |
|
appendValueElement(out, value); |
|
out << STRLIT("</RETURNVALUE>\n"); |
|
} |
|
|
|
//------------------------------------------------------------------------------ |
|
// |
|
// _appendIReturnValueElementBegin() |
|
// _appendIReturnValueElementEnd() |
|
// |
|
// <!ELEMENT IRETURNVALUE (CLASSNAME*|INSTANCENAME*|VALUE*| |
|
// VALUE.OBJECTWITHPATH*|VALUE.OBJECTWITHLOCALPATH*|VALUE.OBJECT*| |
|
// OBJECTPATH*|QUALIFIER.DECLARATION*|VALUE.ARRAY?|VALUE.REFERENCE?| |
|
// CLASS*|INSTANCE*|VALUE.NAMEDINSTANCE*)> |
|
// |
|
//------------------------------------------------------------------------------ |
|
|
|
void XmlWriter::_appendIReturnValueElementBegin( |
|
Buffer& out) |
|
{ |
|
out << STRLIT("<IRETURNVALUE>\n"); |
|
} |
|
|
|
void XmlWriter::_appendIReturnValueElementEnd( |
|
Buffer& out) |
|
{ |
|
out << STRLIT("</IRETURNVALUE>\n"); |
|
} |
|
|
|
//------------------------------------------------------------------------------ |
|
// |
|
// appendBooleanIParameter() |
|
// |
|
//------------------------------------------------------------------------------ |
|
|
|
void XmlWriter::appendBooleanIParameter( |
|
Buffer& out, |
|
const char* name, |
|
Boolean flag) |
|
{ |
|
_appendIParamValueElementBegin(out, name); |
|
out << STRLIT("<VALUE>"); |
|
append(out, flag); |
|
out << STRLIT("</VALUE>\n"); |
|
_appendIParamValueElementEnd(out); |
|
} |
|
|
|
//------------------------------------------------------------------------------ |
|
// |
|
// appendStringIParameter() |
|
// |
|
//------------------------------------------------------------------------------ |
|
|
|
void XmlWriter::appendStringIParameter( |
|
Buffer& out, |
|
const char* name, |
|
const String& str) |
|
{ |
|
_appendIParamValueElementBegin(out, name); |
|
out << STRLIT("<VALUE>"); |
|
appendSpecial(out, str); |
|
out << STRLIT("</VALUE>\n"); |
|
_appendIParamValueElementEnd(out); |
|
} |
|
|
|
//------------------------------------------------------------------------------ |
|
// |
|
// appendClassNameIParameter() |
|
// |
|
//------------------------------------------------------------------------------ |
|
|
|
void XmlWriter::appendClassNameIParameter( |
|
Buffer& out, |
|
const char* name, |
|
const CIMName& className) |
|
{ |
|
_appendIParamValueElementBegin(out, name); |
|
|
|
// |
|
// A NULL (unassigned) value for a parameter is specified by an |
|
// <IPARAMVALUE> element with no subelement |
|
// |
|
if (!className.isNull ()) |
|
{ |
|
appendClassNameElement(out, className); |
|
} |
|
|
|
_appendIParamValueElementEnd(out); |
|
} |
|
|
|
//------------------------------------------------------------------------------ |
|
// |
|
// appendInstanceNameIParameter() |
|
// |
|
//------------------------------------------------------------------------------ |
|
|
|
void XmlWriter::appendInstanceNameIParameter( |
|
Buffer& out, |
const char* name, | const char* name, |
Boolean flag) |
const CIMObjectPath& instanceName) |
|
{ |
|
_appendIParamValueElementBegin(out, name); |
|
appendInstanceNameElement(out, instanceName); |
|
_appendIParamValueElementEnd(out); |
|
} |
|
|
|
void XmlWriter::appendObjectNameIParameter( |
|
Buffer& out, |
|
const char* name, |
|
const CIMObjectPath& objectName) |
|
{ |
|
// |
|
// ATTN-CAKG-P2-20020726: The following condition does not correctly |
|
// distinguish instanceNames from classNames in every case |
|
// The instanceName of a singleton instance of a keyless class also |
|
// has no key bindings |
|
// |
|
if (objectName.getKeyBindings ().size () == 0) |
|
{ |
|
XmlWriter::appendClassNameIParameter( |
|
out, name, objectName.getClassName()); |
|
} |
|
else |
{ | { |
Array<Sint8> tmp; |
XmlWriter::appendInstanceNameIParameter( |
tmp << "<VALUE>" << (flag ? "TRUE" : "FALSE") << "</VALUE>\n"; |
out, name, objectName); |
return formatIParamValueElement(out, name, tmp); |
} |
} | } |
| |
//------------------------------------------------------------------------------ | //------------------------------------------------------------------------------ |
// | // |
// appendStringIParameter() |
// appendClassIParameter() |
// | // |
//------------------------------------------------------------------------------ | //------------------------------------------------------------------------------ |
| |
Array<Sint8>& XmlWriter::appendStringIParameter( |
void XmlWriter::appendClassIParameter( |
Array<Sint8>& out, |
Buffer& out, |
const char* name, | const char* name, |
const String& str) |
const CIMConstClass& cimClass) |
{ | { |
Array<Sint8> tmp; |
_appendIParamValueElementBegin(out, name); |
tmp << "<VALUE>"; |
appendClassElement(out, cimClass); |
appendSpecial(tmp, str); |
_appendIParamValueElementEnd(out); |
tmp << "</VALUE>\n"; |
|
return formatIParamValueElement(out, name, tmp); |
|
} | } |
| |
//------------------------------------------------------------------------------ | //------------------------------------------------------------------------------ |
// | // |
// appendClassNameParameter() |
// appendInstanceIParameter() |
// | // |
//------------------------------------------------------------------------------ | //------------------------------------------------------------------------------ |
| |
Array<Sint8>& XmlWriter::appendClassNameParameter( |
void XmlWriter::appendInstanceIParameter( |
Array<Sint8>& out, |
Buffer& out, |
const char* name, | const char* name, |
const String& className) |
const CIMConstInstance& instance) |
{ | { |
Array<Sint8> tmp; |
_appendIParamValueElementBegin(out, name); |
appendClassNameElement(tmp, className); |
appendInstanceElement(out, instance); |
return formatIParamValueElement(out, name, tmp); |
_appendIParamValueElementEnd(out); |
} | } |
| |
//------------------------------------------------------------------------------ | //------------------------------------------------------------------------------ |
// | // |
// appendQualifierNameParameter() |
// appendNamedInstanceIParameter() |
// | // |
//------------------------------------------------------------------------------ | //------------------------------------------------------------------------------ |
| |
Array<Sint8>& XmlWriter::appendQualifierNameParameter( |
void XmlWriter::appendNamedInstanceIParameter( |
Array<Sint8>& out, |
Buffer& out, |
const char* name, | const char* name, |
const String& qualifierName) |
const CIMInstance& namedInstance) |
{ | { |
// <!ELEMENT IPARAMVALUE (VALUE|VALUE.ARRAY|VALUE.REFERENCE |
_appendIParamValueElementBegin(out, name); |
// |INSTANCENAME|CLASSNAME|QUALIFIER.DECLARATION |
appendValueNamedInstanceElement(out, namedInstance); |
// |CLASS|INSTANCE|VALUE.NAMEDINSTANCE)?> |
_appendIParamValueElementEnd(out); |
|
} |
|
|
|
//---------------------------------------------------------- |
|
// |
|
// appendPropertyNameIParameter() |
|
// |
|
// </IPARAMVALUE> |
|
// <IPARAMVALUE NAME="PropertyName"><VALUE>FreeSpace</VALUE></IPARAMVALUE> |
|
// |
|
// USE: Create parameter for getProperty operation |
|
//========================================================== |
|
void XmlWriter::appendPropertyNameIParameter( |
|
Buffer& out, |
|
const CIMName& propertyName) |
|
{ |
|
_appendIParamValueElementBegin(out, "PropertyName"); |
|
out << STRLIT("<VALUE>") << propertyName << STRLIT("</VALUE>\n"); |
|
_appendIParamValueElementEnd(out); |
|
} |
|
|
|
//------------------------------------------------------------------------------ |
// | // |
// ATTN: notice that there is really no way to pass a qualifier name |
// appendPropertyValueIParameter() |
// as an IPARAMVALUE element according to the spec (look above). So we |
// |
// just pass it as a class name. An answer must be obtained later. |
//------------------------------------------------------------------------------ |
| |
Array<Sint8> tmp; |
void XmlWriter::appendPropertyValueIParameter( |
appendClassNameElement(tmp, qualifierName); |
Buffer& out, |
return formatIParamValueElement(out, name, tmp); |
const char* name, |
|
const CIMValue& value) |
|
{ |
|
_appendIParamValueElementBegin(out, name); |
|
appendValueElement(out, value); |
|
_appendIParamValueElementEnd(out); |
} | } |
| |
//------------------------------------------------------------------------------ | //------------------------------------------------------------------------------ |
// | // |
// appendClassParameter() |
// appendPropertyListIParameter() |
// | // |
//------------------------------------------------------------------------------ | //------------------------------------------------------------------------------ |
| |
Array<Sint8>& XmlWriter::appendClassParameter( |
void XmlWriter::appendPropertyListIParameter( |
Array<Sint8>& out, |
Buffer& out, |
const char* parameterName, |
const CIMPropertyList& propertyList) |
const CIMConstClass& cimClass) |
{ |
|
_appendIParamValueElementBegin(out, "PropertyList"); |
|
|
|
// |
|
// A NULL (unassigned) value for a parameter is specified by an |
|
// <IPARAMVALUE> element with no subelement |
|
// |
|
if (!propertyList.isNull ()) |
|
{ |
|
out << STRLIT("<VALUE.ARRAY>\n"); |
|
for (Uint32 i = 0; i < propertyList.size(); i++) |
{ | { |
Array<Sint8> tmp; |
out << STRLIT("<VALUE>") << propertyList[i] << STRLIT("</VALUE>\n"); |
cimClass.toXml(tmp); |
} |
return formatIParamValueElement(out, parameterName, tmp); |
out << STRLIT("</VALUE.ARRAY>\n"); |
|
} |
|
|
|
_appendIParamValueElementEnd(out); |
} | } |
| |
//------------------------------------------------------------------------------ | //------------------------------------------------------------------------------ |
// | // |
// appendInstanceNameParameter() |
// appendQualifierDeclarationIParameter() |
// | // |
//------------------------------------------------------------------------------ | //------------------------------------------------------------------------------ |
| |
Array<Sint8>& XmlWriter::appendInstanceNameParameter( |
void XmlWriter::appendQualifierDeclarationIParameter( |
Array<Sint8>& out, |
Buffer& out, |
const char* parameterName, |
const char* name, |
const CIMReference& instanceName) |
const CIMConstQualifierDecl& qualifierDecl) |
{ | { |
Array<Sint8> tmp; |
_appendIParamValueElementBegin(out, name); |
instanceName.instanceNameToXml(tmp); |
appendQualifierDeclElement(out, qualifierDecl); |
return formatIParamValueElement(out, parameterName, tmp); |
_appendIParamValueElementEnd(out); |
} | } |
| |
//------------------------------------------------------------------------------ | //------------------------------------------------------------------------------ |
// | // |
// appendInstanceParameter() |
// XmlWriter::formatHttpErrorRspMessage() |
// | // |
//------------------------------------------------------------------------------ | //------------------------------------------------------------------------------ |
| |
Array<Sint8>& XmlWriter::appendInstanceParameter( |
Buffer XmlWriter::formatHttpErrorRspMessage( |
Array<Sint8>& out, |
const String& status, |
const char* parameterName, |
const String& cimError, |
const CIMConstInstance& instance) |
const String& errorDetail) |
|
{ |
|
Buffer out; |
|
|
|
appendHttpErrorResponseHeader(out, status, cimError, errorDetail); |
|
|
|
return out; |
|
} |
|
|
|
// l10n - add content language support to the format methods below |
|
|
|
//------------------------------------------------------------------------------ |
|
// |
|
// XmlWriter::formatSimpleMethodReqMessage() |
|
// |
|
//------------------------------------------------------------------------------ |
|
|
|
// ATTN-RK-P1-20020228: Need to complete copy elimination optimization |
|
Buffer XmlWriter::formatSimpleMethodReqMessage( |
|
const char* host, |
|
const CIMNamespaceName& nameSpace, |
|
const CIMObjectPath& path, |
|
const CIMName& methodName, |
|
const Array<CIMParamValue>& parameters, |
|
const String& messageId, |
|
HttpMethod httpMethod, |
|
const String& authenticationHeader, |
|
const AcceptLanguageList& httpAcceptLanguages, |
|
const ContentLanguageList& httpContentLanguages) |
|
{ |
|
Buffer out; |
|
Buffer tmp; |
|
CIMObjectPath localObjectPath = path; |
|
localObjectPath.setNameSpace(nameSpace.getString()); |
|
localObjectPath.setHost(String::EMPTY); |
|
|
|
_appendMessageElementBegin(out, messageId); |
|
_appendSimpleReqElementBegin(out); |
|
_appendMethodCallElementBegin(out, methodName); |
|
appendLocalObjectPathElement(out, localObjectPath); |
|
for (Uint32 i=0; i < parameters.size(); i++) |
|
{ |
|
appendParamValueElement(out, parameters[i]); |
|
} |
|
_appendMethodCallElementEnd(out); |
|
_appendSimpleReqElementEnd(out); |
|
_appendMessageElementEnd(out); |
|
|
|
appendMethodCallHeader( |
|
tmp, |
|
host, |
|
methodName, |
|
localObjectPath.toString(), |
|
authenticationHeader, |
|
httpMethod, |
|
httpAcceptLanguages, |
|
httpContentLanguages, |
|
out.size()); |
|
tmp << out; |
|
|
|
return tmp; |
|
} |
|
|
|
//PEP 128 adding serverRsponseTime to header |
|
Buffer XmlWriter::formatSimpleMethodRspMessage( |
|
const CIMName& methodName, |
|
const String& messageId, |
|
HttpMethod httpMethod, |
|
const ContentLanguageList& httpContentLanguages, |
|
const Buffer& body, |
|
Uint64 serverResponseTime, |
|
Boolean isFirst, |
|
Boolean isLast) |
|
{ |
|
Buffer out; |
|
|
|
if (isFirst == true) |
|
{ |
|
// NOTE: temporarily put zero for content length. the http code |
|
// will later decide to fill in the length or remove it altogether |
|
appendMethodResponseHeader(out, httpMethod, httpContentLanguages, 0, |
|
serverResponseTime); |
|
_appendMessageElementBegin(out, messageId); |
|
_appendSimpleRspElementBegin(out); |
|
_appendMethodResponseElementBegin(out, methodName); |
|
} |
|
|
|
if (body.size() != 0) |
|
{ |
|
out << body; |
|
} |
|
|
|
if (isLast == true) |
{ | { |
Array<Sint8> tmp; |
_appendMethodResponseElementEnd(out); |
instance.toXml(tmp); |
_appendSimpleRspElementEnd(out); |
return formatIParamValueElement(out, parameterName, tmp); |
_appendMessageElementEnd(out); |
|
} |
|
|
|
return out; |
} | } |
| |
|
|
|
|
//------------------------------------------------------------------------------ | //------------------------------------------------------------------------------ |
// | // |
// appendNamedInstanceParameter() |
// XmlWriter::formatSimpleMethodErrorRspMessage() |
// | // |
//------------------------------------------------------------------------------ | //------------------------------------------------------------------------------ |
| |
Array<Sint8>& XmlWriter::appendNamedInstanceParameter( |
Buffer XmlWriter::formatSimpleMethodErrorRspMessage( |
Array<Sint8>& out, |
const CIMName& methodName, |
const char* parameterName, |
const String& messageId, |
const CIMNamedInstance& namedInstance) |
HttpMethod httpMethod, |
|
const CIMException& cimException) |
{ | { |
Array<Sint8> tmp; |
Buffer out; |
namedInstance.toXml(tmp); |
Buffer tmp; |
return formatIParamValueElement(out, parameterName, tmp); |
|
|
_appendMessageElementBegin(out, messageId); |
|
_appendSimpleRspElementBegin(out); |
|
_appendMethodResponseElementBegin(out, methodName); |
|
_appendErrorElement(out, cimException); |
|
_appendMethodResponseElementEnd(out); |
|
_appendSimpleRspElementEnd(out); |
|
_appendMessageElementEnd(out); |
|
|
|
// l10n |
|
appendMethodResponseHeader(tmp, |
|
httpMethod, |
|
cimException.getContentLanguages(), |
|
out.size()); |
|
tmp << out; |
|
|
|
return tmp; |
} | } |
| |
//---------------------------------------------------------- |
//------------------------------------------------------------------------------ |
// | // |
// appendPropertyNameParameter() |
// XmlWriter::formatSimpleIMethodReqMessage() |
// | // |
// </IPARAMVALUE> |
//------------------------------------------------------------------------------ |
// <IPARAMVALUE NAME="PropertyName"><VALUE>FreeSpace</VALUE></IPARAMVALUE> |
|
|
Buffer XmlWriter::formatSimpleIMethodReqMessage( |
|
const char* host, |
|
const CIMNamespaceName& nameSpace, |
|
const CIMName& iMethodName, |
|
const String& messageId, |
|
HttpMethod httpMethod, |
|
const String& authenticationHeader, |
|
const AcceptLanguageList& httpAcceptLanguages, |
|
const ContentLanguageList& httpContentLanguages, |
|
const Buffer& body) |
|
{ |
|
Buffer out; |
|
Buffer tmp; |
|
|
|
_appendMessageElementBegin(out, messageId); |
|
_appendSimpleReqElementBegin(out); |
|
_appendIMethodCallElementBegin(out, iMethodName); |
|
appendLocalNameSpacePathElement(out, nameSpace.getString()); |
|
out << body; |
|
_appendIMethodCallElementEnd(out); |
|
_appendSimpleReqElementEnd(out); |
|
_appendMessageElementEnd(out); |
|
|
|
appendMethodCallHeader( |
|
tmp, |
|
host, |
|
iMethodName, |
|
nameSpace.getString(), |
|
authenticationHeader, |
|
httpMethod, |
|
httpAcceptLanguages, |
|
httpContentLanguages, |
|
out.size()); |
|
tmp << out; |
|
|
|
return tmp; |
|
} |
|
|
|
//------------------------------------------------------------------------------ |
// | // |
// USE: Create parameter for getProperty operation |
// XmlWriter::formatSimpleIMethodRspMessage() |
//========================================================== |
// |
Array<Sint8>& XmlWriter::appendPropertyNameParameter( |
//------------------------------------------------------------------------------ |
Array<Sint8>& out, |
|
const String& propertyName) |
Buffer XmlWriter::formatSimpleIMethodRspMessage( |
|
const CIMName& iMethodName, |
|
const String& messageId, |
|
HttpMethod httpMethod, |
|
const ContentLanguageList& httpContentLanguages, |
|
const Buffer& body, |
|
Uint64 serverResponseTime, |
|
Boolean isFirst, |
|
Boolean isLast) |
|
{ |
|
Buffer out; |
|
|
|
if (isFirst == true) |
|
{ |
|
// NOTE: temporarily put zero for content length. the http code |
|
// will later decide to fill in the length or remove it altogether |
|
appendMethodResponseHeader(out, httpMethod, httpContentLanguages, 0, |
|
serverResponseTime); |
|
_appendMessageElementBegin(out, messageId); |
|
_appendSimpleRspElementBegin(out); |
|
_appendIMethodResponseElementBegin(out, iMethodName); |
|
|
|
// output the start of the return tag. Test if there is response data by: |
|
// 1. there is data on the first chunk OR |
|
// 2. there is no data on the first chunk but isLast is false implying |
|
// there is more non-empty data to come. If all subsequent chunks |
|
// are empty, then this generates and empty response. |
|
if (body.size() != 0 || isLast == false) |
|
_appendIReturnValueElementBegin(out); |
|
} |
|
|
|
if (body.size() != 0) |
|
{ |
|
out << body; |
|
} |
|
|
|
if (isLast == true) |
{ | { |
Array<Sint8> tmp; |
if (body.size() != 0 || isFirst == false) |
tmp << "<VALUE>" << propertyName << "</VALUE>\n"; |
_appendIReturnValueElementEnd(out); |
return formatIParamValueElement(out,"PropertyName", tmp);} |
_appendIMethodResponseElementEnd(out); |
|
_appendSimpleRspElementEnd(out); |
|
_appendMessageElementEnd(out); |
|
} |
|
|
|
return out; |
|
} |
|
|
| |
//------------------------------------------------------------------------------ | //------------------------------------------------------------------------------ |
// | // |
// appendPropertyValueParameter() |
// XmlWriter::formatSimpleIMethodErrorRspMessage() |
// | // |
//------------------------------------------------------------------------------ | //------------------------------------------------------------------------------ |
| |
Array<Sint8>& XmlWriter::appendPropertyValueParameter( |
Buffer XmlWriter::formatSimpleIMethodErrorRspMessage( |
Array<Sint8>& out, |
const CIMName& iMethodName, |
const char* parameterName, |
const String& messageId, |
const CIMValue& value) |
HttpMethod httpMethod, |
|
const CIMException& cimException) |
|
{ |
|
Buffer out; |
|
Buffer tmp; |
|
|
|
_appendMessageElementBegin(out, messageId); |
|
_appendSimpleRspElementBegin(out); |
|
_appendIMethodResponseElementBegin(out, iMethodName); |
|
_appendErrorElement(out, cimException); |
|
_appendIMethodResponseElementEnd(out); |
|
_appendSimpleRspElementEnd(out); |
|
_appendMessageElementEnd(out); |
|
|
|
// l10n |
|
appendMethodResponseHeader(tmp, |
|
httpMethod, |
|
cimException.getContentLanguages(), |
|
out.size()); |
|
tmp << out; |
|
|
|
return tmp; |
|
} |
|
|
|
//****************************************************************************** |
|
// |
|
// Export Messages (used for indications) |
|
// |
|
//****************************************************************************** |
|
|
|
//------------------------------------------------------------------------------ |
|
// |
|
// appendEMethodRequestHeader() |
|
// |
|
// Build HTTP request header for export operation. |
|
// |
|
//------------------------------------------------------------------------------ |
|
|
|
void XmlWriter::appendEMethodRequestHeader( |
|
Buffer& out, |
|
const char* requestUri, |
|
const char* host, |
|
const CIMName& cimMethod, |
|
HttpMethod httpMethod, |
|
const String& authenticationHeader, |
|
const AcceptLanguageList& acceptLanguages, |
|
const ContentLanguageList& contentLanguages, |
|
Uint32 contentLength) |
|
{ |
|
char nn[] = { '0' + (rand() % 10), '0' + (rand() % 10), '\0' }; |
|
|
|
if (httpMethod == HTTP_METHOD_M_POST) |
|
{ |
|
out << STRLIT("M-POST ") << requestUri << STRLIT(" HTTP/1.1\r\n"); |
|
} |
|
else |
|
{ |
|
out << STRLIT("POST ") << requestUri << STRLIT(" HTTP/1.1\r\n"); |
|
} |
|
out << STRLIT("HOST: ") << host << STRLIT("\r\n"); |
|
out << STRLIT("Content-Type: application/xml; charset=\"utf-8\"\r\n"); |
|
OUTPUT_CONTENTLENGTH; |
|
|
|
if (acceptLanguages.size() > 0) |
|
{ |
|
out << STRLIT("Accept-Language: ") << acceptLanguages << STRLIT("\r\n"); |
|
} |
|
if (contentLanguages.size() > 0) |
|
{ |
|
out << STRLIT("Content-Language: ") << contentLanguages << STRLIT("\r\n"); |
|
} |
|
|
|
#ifdef PEGASUS_DEBUG |
|
// backdoor environment variable to turn OFF client requesting transfer |
|
// encoding. The default is on. to turn off, set this variable to zero. |
|
// This should be removed when stable. This should only be turned off in |
|
// a debugging/testing environment. |
|
|
|
static const char *clientTransferEncodingOff = |
|
getenv("PEGASUS_HTTP_TRANSFER_ENCODING_REQUEST"); |
|
if (!clientTransferEncodingOff || *clientTransferEncodingOff != '0') |
|
#endif |
|
out << STRLIT("TE: chunked, trailers\r\n"); |
|
|
|
if (httpMethod == HTTP_METHOD_M_POST) |
|
{ |
|
out << STRLIT("Man: http://www.dmtf.org/cim/mapping/http/v1.0; ns="); |
|
out << nn << STRLIT("\r\n"); |
|
out << nn << STRLIT("-CIMExport: MethodRequest\r\n"); |
|
out << nn << STRLIT("-CIMExportMethod: ") << cimMethod << STRLIT("\r\n"); |
|
} |
|
else |
|
{ |
|
out << STRLIT("CIMExport: MethodRequest\r\n"); |
|
out << STRLIT("CIMExportMethod: ") << cimMethod << STRLIT("\r\n"); |
|
} |
|
|
|
if (authenticationHeader.size()) |
|
{ |
|
out << authenticationHeader << STRLIT("\r\n"); |
|
} |
|
|
|
out << STRLIT("\r\n"); |
|
} |
|
|
|
//------------------------------------------------------------------------------ |
|
// |
|
// appendEMethodResponseHeader() |
|
// |
|
// Build HTTP response header for export operation. |
|
// |
|
//------------------------------------------------------------------------------ |
|
|
|
void XmlWriter::appendEMethodResponseHeader( |
|
Buffer& out, |
|
HttpMethod httpMethod, |
|
const ContentLanguageList& contentLanguages, |
|
Uint32 contentLength) |
|
{ |
|
char nn[] = { '0' + (rand() % 10), '0' + (rand() % 10), '\0' }; |
|
|
|
out << STRLIT("HTTP/1.1 " HTTP_STATUS_OK "\r\n"); |
|
out << STRLIT("Content-Type: application/xml; charset=\"utf-8\"\r\n"); |
|
OUTPUT_CONTENTLENGTH; |
|
|
|
if (contentLanguages.size() > 0) |
{ | { |
Array<Sint8> tmp; |
out << STRLIT("Content-Language: ") << contentLanguages << STRLIT("\r\n"); |
value.toXml(tmp); |
} |
return formatIParamValueElement(out, parameterName, tmp); |
if (httpMethod == HTTP_METHOD_M_POST) |
|
{ |
|
out << STRLIT("Ext:\r\n"); |
|
out << STRLIT("Cache-Control: no-cache\r\n"); |
|
out << STRLIT("Man: http://www.dmtf.org/cim/mapping/http/v1.0; ns="); |
|
out << nn << STRLIT("\r\n"); |
|
out << nn << STRLIT("-CIMExport: MethodResponse\r\n\r\n"); |
|
} |
|
else |
|
{ |
|
out << STRLIT("CIMExport: MethodResponse\r\n\r\n"); |
|
} |
|
} |
|
|
|
//------------------------------------------------------------------------------ |
|
// |
|
// _appendSimpleExportReqElementBegin() |
|
// _appendSimpleExportReqElementEnd() |
|
// |
|
// <!ELEMENT SIMPLEEXPREQ (EXPMETHODCALL)> |
|
// |
|
//------------------------------------------------------------------------------ |
|
|
|
void XmlWriter::_appendSimpleExportReqElementBegin( |
|
Buffer& out) |
|
{ |
|
out << STRLIT("<SIMPLEEXPREQ>\n"); |
|
} |
|
|
|
void XmlWriter::_appendSimpleExportReqElementEnd( |
|
Buffer& out) |
|
{ |
|
out << STRLIT("</SIMPLEEXPREQ>\n"); |
|
} |
|
|
|
//------------------------------------------------------------------------------ |
|
// |
|
// _appendEMethodCallElementBegin() |
|
// _appendEMethodCallElementEnd() |
|
// |
|
// <!ELEMENT EXPMETHODCALL (IPARAMVALUE*)> |
|
// <!ATTLIST EXPMETHODCALL %CIMName;> |
|
// |
|
//------------------------------------------------------------------------------ |
|
|
|
void XmlWriter::_appendEMethodCallElementBegin( |
|
Buffer& out, |
|
const CIMName& name) |
|
{ |
|
out << STRLIT("<EXPMETHODCALL NAME=\"") << name << STRLIT("\">\n"); |
|
} |
|
|
|
void XmlWriter::_appendEMethodCallElementEnd( |
|
Buffer& out) |
|
{ |
|
out << STRLIT("</EXPMETHODCALL>\n"); |
|
} |
|
|
|
//------------------------------------------------------------------------------ |
|
// |
|
// _appendEParamValueElementBegin() |
|
// _appendEParamValueElementEnd() |
|
// |
|
// <!ELEMENT EXPPARAMVALUE (INSTANCE)> |
|
// <!ATTLIST EXPPARAMVALUE |
|
// %CIMName;> |
|
// |
|
//------------------------------------------------------------------------------ |
|
|
|
void XmlWriter::_appendEParamValueElementBegin( |
|
Buffer& out, |
|
const char* name) |
|
{ |
|
out << STRLIT("<EXPPARAMVALUE NAME=\"") << name << STRLIT("\">\n"); |
|
} |
|
|
|
void XmlWriter::_appendEParamValueElementEnd( |
|
Buffer& out) |
|
{ |
|
out << STRLIT("</EXPPARAMVALUE>\n"); |
|
} |
|
|
|
//------------------------------------------------------------------------------ |
|
// |
|
// appendInstanceEParameter() |
|
// |
|
//------------------------------------------------------------------------------ |
|
|
|
void XmlWriter::appendInstanceEParameter( |
|
Buffer& out, |
|
const char* name, |
|
const CIMInstance& instance) |
|
{ |
|
_appendEParamValueElementBegin(out, name); |
|
appendInstanceElement(out, instance); |
|
_appendEParamValueElementEnd(out); |
|
} |
|
|
|
//------------------------------------------------------------------------------ |
|
// |
|
// _appendSimpleExportRspElementBegin() |
|
// _appendSimpleExportRspElementEnd() |
|
// |
|
// <!ELEMENT SIMPLEEXPRSP (EXPMETHODRESPONSE)> |
|
// |
|
//------------------------------------------------------------------------------ |
|
|
|
void XmlWriter::_appendSimpleExportRspElementBegin( |
|
Buffer& out) |
|
{ |
|
out << STRLIT("<SIMPLEEXPRSP>\n"); |
|
} |
|
|
|
void XmlWriter::_appendSimpleExportRspElementEnd( |
|
Buffer& out) |
|
{ |
|
out << STRLIT("</SIMPLEEXPRSP>\n"); |
} | } |
| |
//------------------------------------------------------------------------------ | //------------------------------------------------------------------------------ |
// | // |
// appendPropertyListParameter() |
// _appendEMethodResponseElementBegin() |
|
// _appendEMethodResponseElementEnd() |
|
// |
|
// <!ELEMENT EXPMETHODRESPONSE (ERROR|IRETURNVALUE?)> |
|
// <!ATTLIST EXPMETHODRESPONSE %CIMName;> |
// | // |
//------------------------------------------------------------------------------ | //------------------------------------------------------------------------------ |
| |
Array<Sint8>& XmlWriter::appendPropertyListParameter( |
void XmlWriter::_appendEMethodResponseElementBegin( |
Array<Sint8>& out, |
Buffer& out, |
const CIMPropertyList& propertyList) |
const CIMName& name) |
{ | { |
Array<Sint8> tmp; |
out << STRLIT("<EXPMETHODRESPONSE NAME=\"") << name << STRLIT("\">\n"); |
|
} |
| |
tmp << "<VALUE.ARRAY>\n"; |
void XmlWriter::_appendEMethodResponseElementEnd( |
for (Uint32 i = 0; i < propertyList.getNumProperties(); i++) |
Buffer& out) |
{ | { |
tmp << "<VALUE>" << propertyList.getPropertyName(i) << "</VALUE>\n"; |
out << STRLIT("</EXPMETHODRESPONSE>\n"); |
} |
|
tmp << "</VALUE.ARRAY>\n"; |
|
return formatIParamValueElement(out, "PropertyList", tmp); |
|
} | } |
| |
//------------------------------------------------------------------------------ | //------------------------------------------------------------------------------ |
// | // |
// appendQualifierDeclarationParameter() |
// XmlWriter::formatSimpleEMethodReqMessage() |
// | // |
//------------------------------------------------------------------------------ | //------------------------------------------------------------------------------ |
| |
Array<Sint8>& XmlWriter::appendQualifierDeclarationParameter( |
Buffer XmlWriter::formatSimpleEMethodReqMessage( |
Array<Sint8>& out, |
const char* requestUri, |
const char* parameterName, |
const char* host, |
const CIMConstQualifierDecl& qualifierDecl) |
const CIMName& eMethodName, |
{ |
const String& messageId, |
Array<Sint8> tmp; |
HttpMethod httpMethod, |
qualifierDecl.toXml(tmp); |
const String& authenticationHeader, |
return formatIParamValueElement(out, parameterName, tmp); |
const AcceptLanguageList& httpAcceptLanguages, |
|
const ContentLanguageList& httpContentLanguages, |
|
const Buffer& body) |
|
{ |
|
Buffer out; |
|
Buffer tmp; |
|
|
|
_appendMessageElementBegin(out, messageId); |
|
_appendSimpleExportReqElementBegin(out); |
|
_appendEMethodCallElementBegin(out, eMethodName); |
|
out << body; |
|
_appendEMethodCallElementEnd(out); |
|
_appendSimpleExportReqElementEnd(out); |
|
_appendMessageElementEnd(out); |
|
|
|
appendEMethodRequestHeader( |
|
tmp, |
|
requestUri, |
|
host, |
|
eMethodName, |
|
httpMethod, |
|
authenticationHeader, |
|
httpAcceptLanguages, |
|
httpContentLanguages, |
|
out.size()); |
|
tmp << out; |
|
|
|
return tmp; |
} | } |
| |
//------------------------------------------------------------------------------ | //------------------------------------------------------------------------------ |
// | // |
// appendClassNameElement() |
// XmlWriter::formatSimpleEMethodRspMessage() |
// | // |
//------------------------------------------------------------------------------ | //------------------------------------------------------------------------------ |
| |
Array<Sint8>& XmlWriter::appendClassNameElement( |
Buffer XmlWriter::formatSimpleEMethodRspMessage( |
Array<Sint8>& out, |
const CIMName& eMethodName, |
const String& className) |
const String& messageId, |
{ |
HttpMethod httpMethod, |
return out << "<CLASSNAME NAME=\"" << className << "\"/>\n"; |
const ContentLanguageList& httpContentLanguages, |
|
const Buffer& body) |
|
{ |
|
Buffer out; |
|
Buffer tmp; |
|
|
|
_appendMessageElementBegin(out, messageId); |
|
_appendSimpleExportRspElementBegin(out); |
|
_appendEMethodResponseElementBegin(out, eMethodName); |
|
out << body; |
|
_appendEMethodResponseElementEnd(out); |
|
_appendSimpleExportRspElementEnd(out); |
|
_appendMessageElementEnd(out); |
|
|
|
appendEMethodResponseHeader(tmp, |
|
httpMethod, |
|
httpContentLanguages, |
|
out.size()); |
|
tmp << out; |
|
|
|
return tmp; |
} | } |
| |
//------------------------------------------------------------------------------ | //------------------------------------------------------------------------------ |
// | // |
// appendInstanceNameElement() |
// XmlWriter::formatSimpleEMethodErrorRspMessage() |
// | // |
//------------------------------------------------------------------------------ | //------------------------------------------------------------------------------ |
| |
Array<Sint8>& XmlWriter::appendInstanceNameElement( |
Buffer XmlWriter::formatSimpleEMethodErrorRspMessage( |
Array<Sint8>& out, |
const CIMName& eMethodName, |
const CIMReference& instanceName) |
const String& messageId, |
|
HttpMethod httpMethod, |
|
const CIMException& cimException) |
{ | { |
instanceName.instanceNameToXml(out); |
Buffer out; |
return out; |
Buffer tmp; |
|
|
|
_appendMessageElementBegin(out, messageId); |
|
_appendSimpleExportRspElementBegin(out); |
|
_appendEMethodResponseElementBegin(out, eMethodName); |
|
_appendErrorElement(out, cimException); |
|
_appendEMethodResponseElementEnd(out); |
|
_appendSimpleExportRspElementEnd(out); |
|
_appendMessageElementEnd(out); |
|
|
|
// l10n |
|
appendEMethodResponseHeader(tmp, |
|
httpMethod, |
|
cimException.getContentLanguages(), |
|
out.size()); |
|
tmp << out; |
|
|
|
return tmp; |
} | } |
| |
//------------------------------------------------------------------------------ | //------------------------------------------------------------------------------ |
// | // |
// _printAttributes() |
// _xmlWritter_printAttributes() |
// | // |
//------------------------------------------------------------------------------ | //------------------------------------------------------------------------------ |
| |
static void _printAttributes( |
void _xmlWritter_printAttributes( |
PEGASUS_STD(ostream)& os, | PEGASUS_STD(ostream)& os, |
const XmlAttribute* attributes, | const XmlAttribute* attributes, |
Uint32 attributeCount) | Uint32 attributeCount) |
|
|
os << attributes[i].name << "="; | os << attributes[i].name << "="; |
| |
os << '"'; | os << '"'; |
AppendSpecial(os, attributes[i].value); |
_xmlWritter_appendSpecial(os, attributes[i].value); |
os << '"'; | os << '"'; |
| |
if (i + 1 != attributeCount) | if (i + 1 != attributeCount) |
|
|
| |
//------------------------------------------------------------------------------ | //------------------------------------------------------------------------------ |
// | // |
// _indent() |
// _xmlWritter_indent() |
// | // |
//------------------------------------------------------------------------------ | //------------------------------------------------------------------------------ |
| |
static void _indent(PEGASUS_STD(ostream)& os, Uint32 level, Uint32 indentChars) |
void _xmlWritter_indent(PEGASUS_STD(ostream)& os, Uint32 level, Uint32 indentChars) |
{ | { |
Uint32 n = level * indentChars; | Uint32 n = level * indentChars; |
| |
|
|
const char* text, | const char* text, |
Uint32 indentChars) | Uint32 indentChars) |
{ | { |
char* tmp = strcpy(new char[strlen(text) + 1], text); |
AutoArrayPtr<char> tmp(strcpy(new char[strlen(text) + 1], text)); |
| |
XmlParser parser(tmp); |
XmlParser parser(tmp.get()); |
XmlEntry entry; | XmlEntry entry; |
Stack<const char*> stack; | Stack<const char*> stack; |
| |
|
|
{ | { |
case XmlEntry::XML_DECLARATION: | case XmlEntry::XML_DECLARATION: |
{ | { |
_indent(os, stack.size(), indentChars); |
_xmlWritter_indent(os, stack.size(), indentChars); |
| |
os << "<?" << entry.text << " "; | os << "<?" << entry.text << " "; |
_printAttributes(os, entry.attributes, entry.attributeCount); |
_xmlWritter_printAttributes(os, entry.attributes, entry.attributeCount); |
os << "?>"; | os << "?>"; |
break; | break; |
} | } |
| |
case XmlEntry::START_TAG: | case XmlEntry::START_TAG: |
{ | { |
_indent(os, stack.size(), indentChars); |
_xmlWritter_indent(os, stack.size(), indentChars); |
| |
os << "<" << entry.text; | os << "<" << entry.text; |
| |
if (entry.attributeCount) | if (entry.attributeCount) |
os << ' '; | os << ' '; |
| |
_printAttributes(os, entry.attributes, entry.attributeCount); |
_xmlWritter_printAttributes(os, entry.attributes, entry.attributeCount); |
os << ">"; | os << ">"; |
stack.push(entry.text); | stack.push(entry.text); |
break; | break; |
|
|
| |
case XmlEntry::EMPTY_TAG: | case XmlEntry::EMPTY_TAG: |
{ | { |
_indent(os, stack.size(), indentChars); |
_xmlWritter_indent(os, stack.size(), indentChars); |
| |
os << "<" << entry.text << " "; | os << "<" << entry.text << " "; |
_printAttributes(os, entry.attributes, entry.attributeCount); |
_xmlWritter_printAttributes(os, entry.attributes, entry.attributeCount); |
os << "/>"; | os << "/>"; |
break; | break; |
} | } |
|
|
if (!stack.isEmpty() && strcmp(stack.top(), entry.text) == 0) | if (!stack.isEmpty() && strcmp(stack.top(), entry.text) == 0) |
stack.pop(); | stack.pop(); |
| |
_indent(os, stack.size(), indentChars); |
_xmlWritter_indent(os, stack.size(), indentChars); |
| |
os << "</" << entry.text << ">"; | os << "</" << entry.text << ">"; |
break; | break; |
|
|
case XmlEntry::COMMENT: | case XmlEntry::COMMENT: |
{ | { |
| |
_indent(os, stack.size(), indentChars); |
_xmlWritter_indent(os, stack.size(), indentChars); |
os << "<!--"; | os << "<!--"; |
AppendSpecial(os, entry.text); |
_xmlWritter_appendSpecial(os, entry.text); |
os << "-->"; | os << "-->"; |
break; | break; |
} | } |
| |
case XmlEntry::CONTENT: | case XmlEntry::CONTENT: |
{ | { |
_indent(os, stack.size(), indentChars); |
_xmlWritter_indent(os, stack.size(), indentChars); |
AppendSpecial(os, entry.text); |
_xmlWritter_appendSpecial(os, entry.text); |
break; | break; |
} | } |
| |
case XmlEntry::CDATA: | case XmlEntry::CDATA: |
{ | { |
_indent(os, stack.size(), indentChars); |
_xmlWritter_indent(os, stack.size(), indentChars); |
os << "<![CDATA[...]]>"; |
os << "<![CDATA[" << entry.text << "]]>"; |
break; | break; |
} | } |
| |
case XmlEntry::DOCTYPE: | case XmlEntry::DOCTYPE: |
{ | { |
_indent(os, stack.size(), indentChars); |
_xmlWritter_indent(os, stack.size(), indentChars); |
os << "<!DOCTYPE...>"; | os << "<!DOCTYPE...>"; |
break; | break; |
} | } |
|
|
os << PEGASUS_STD(endl); | os << PEGASUS_STD(endl); |
} | } |
| |
delete [] tmp; |
|
} | } |
| |
//------------------------------------------------------------------------------ | //------------------------------------------------------------------------------ |
|
|
// | // |
//------------------------------------------------------------------------------ | //------------------------------------------------------------------------------ |
| |
|
static IDFactory _messageIDFactory(1000); |
|
|
String XmlWriter::getNextMessageId() | String XmlWriter::getNextMessageId() |
{ | { |
// ATTN: make thread-safe: |
|
static Uint32 messageId = 1000; |
|
|
|
messageId++; |
|
|
|
if (messageId < 1000) |
|
messageId = 1001; |
|
|
|
char buffer[16]; | char buffer[16]; |
sprintf(buffer, "%d", messageId); |
sprintf(buffer, "%u", _messageIDFactory.getID()); |
return buffer; | return buffer; |
} | } |
| |
//------------------------------------------------------------------------------ | //------------------------------------------------------------------------------ |
// | // |
// XmlWriter::formatSimpleIMethodReqMessage() |
// XmlWriter::keyBindingTypeToString |
// |
|
//------------------------------------------------------------------------------ |
|
|
|
Array<Sint8> XmlWriter::formatSimpleIMethodReqMessage( |
|
const char* host, |
|
const String& nameSpace, |
|
const char* iMethodName, |
|
const String& messageId, |
|
const String& authenticationHeader, |
|
const Array<Sint8>& body) |
|
{ |
|
return XmlWriter::formatMPostHeader( |
|
host, |
|
"MethodCall", |
|
iMethodName, |
|
nameSpace, |
|
authenticationHeader, |
|
XmlWriter::formatMessageElement( |
|
messageId, |
|
XmlWriter::formatSimpleReqElement( |
|
XmlWriter::formatIMethodCallElement( |
|
iMethodName, |
|
nameSpace, |
|
body)))); |
|
} |
|
|
|
Array<Sint8> XmlWriter::formatSimpleRspMessage( |
|
const char* iMethodName, |
|
const String& messageId, |
|
const Array<Sint8>& body) |
|
{ |
|
return XmlWriter::formatMethodResponseHeader( |
|
XmlWriter::formatMessageElement( |
|
messageId, |
|
XmlWriter::formatSimpleRspElement( |
|
XmlWriter::formatIMethodResponseElement( |
|
iMethodName, |
|
XmlWriter::formatIReturnValueElement(body))))); |
|
} |
|
|
|
Array<Sint8>& operator<<(Array<Sint8>& out, const char* x) |
|
{ |
|
XmlWriter::append(out, x); |
|
return out; |
|
} |
|
|
|
Array<Sint8>& operator<<(Array<Sint8>& out, char x) |
|
{ |
|
XmlWriter::append(out, x); |
|
return out; |
|
} |
|
|
|
Array<Sint8>& operator<<(Array<Sint8>& out, Char16 x) |
|
{ |
|
XmlWriter::append(out, x); |
|
return out; |
|
} |
|
|
|
Array<Sint8>& operator<<(Array<Sint8>& out, const String& x) |
|
{ |
|
XmlWriter::append(out, x); |
|
return out; |
|
} |
|
|
|
Array<Sint8>& operator<<(Array<Sint8>& out, const Indentor& x) |
|
{ |
|
XmlWriter::append(out, x); |
|
return out; |
|
} |
|
|
|
Array<Sint8>& operator<<(Array<Sint8>& out, const Array<Sint8>& x) |
|
{ |
|
out.appendArray(x); |
|
return out; |
|
} |
|
|
|
Array<Sint8>& operator<<(Array<Sint8>& out, Uint32 x) |
|
{ |
|
XmlWriter::append(out, x); |
|
return out; |
|
} |
|
|
|
Array<Sint8>& XmlWriter::appendObjectNameParameter( |
|
Array<Sint8>& out, |
|
const char* name, |
|
const CIMReference& objectName) |
|
{ |
|
if (objectName.isClassName()) |
|
{ |
|
XmlWriter::appendClassNameParameter( |
|
out, name, objectName.getClassName()); |
|
} |
|
else |
|
{ |
|
XmlWriter::appendInstanceNameParameter( |
|
out, name, objectName); |
|
} |
|
|
|
return out; |
|
} |
|
|
|
Array<Sint8> XmlWriter::formatEMethodCallElement( |
|
const char* name, |
|
const Array<Sint8>& iParamValues) |
|
{ |
|
Array<Sint8> out; |
|
out << "<EXPMETHODCALL NAME=\"" << name << "\">\n"; |
|
out << iParamValues; |
|
out << "</EXPMETHODCALL>\n"; |
|
return out; |
|
} |
|
|
|
Array<Sint8> XmlWriter::formatSimpleIndicationReqMessage( |
|
const char* host, |
|
const char* iMethodName, |
|
const String& messageId, |
|
const String& authenticationHeader, |
|
const Array<Sint8>& body) |
|
{ |
|
return XmlWriter::formatMPostIndicationHeader( |
|
host, |
|
"MethodRequest", |
|
iMethodName, |
|
authenticationHeader, |
|
XmlWriter::formatMessageElement( |
|
messageId, |
|
XmlWriter::formatSimpleExportReqElement( |
|
XmlWriter::formatEMethodCallElement( |
|
iMethodName, |
|
body)))); |
|
} |
|
|
|
Array<Sint8> XmlWriter::formatMPostIndicationHeader( |
|
const char* host, |
|
const char* cimOperation, |
|
const char* cimMethod, |
|
const String& authenticationHeader, |
|
const Array<Sint8>& content) |
|
{ |
|
Array<Sint8> out; |
|
out.reserve(1024); |
|
char nn[] = { '0' + (rand() % 10), '0' + (rand() % 10), '\0' }; |
|
|
|
out << "M-POST /cimom HTTP/1.1\r\n"; |
|
out << "HOST: " << host << "\r\n"; |
|
out << "Content-CIMType: application/xml; charset=\"utf-8\"\r\n"; |
|
out << "Content-Length: " << content.size() << "\r\n"; |
|
out << "Man: http://www.hp.com; ns="; |
|
out << nn <<"\r\n"; |
|
out << nn << "-CIMExport: " << cimOperation << "\r\n"; |
|
out << nn << "-CIMExportMethod: " << cimMethod << "\r\n"; |
|
if (authenticationHeader.size()) |
|
{ |
|
out << authenticationHeader << "\r\n"; |
|
} |
|
out << "\r\n"; |
|
out << content; |
|
return out; |
|
} |
|
|
|
Array<Sint8> XmlWriter::formatSimpleExportReqElement( |
|
const Array<Sint8>& body) |
|
{ |
|
Array<Sint8> out; |
|
return out << "<SIMPLEEXPREQ>\n" << body << "</SIMPLEEXPREQ>\n"; |
|
} |
|
|
|
Array<Sint8> XmlWriter::formatSimpleIndicationRspMessage( |
|
const char* iMethodName, |
|
const String& messageId, |
|
const Array<Sint8>& body) |
|
{ |
|
return XmlWriter::formatEMethodResponseHeader( |
|
XmlWriter::formatMessageElement( |
|
messageId, |
|
XmlWriter::formatSimpleExportRspElement( |
|
XmlWriter::formatEMethodResponseElement( |
|
iMethodName, |
|
XmlWriter::formatIReturnValueElement(body))))); |
|
} |
|
|
|
//------------------------------------------------------------------------------ |
|
// |
|
// formatSimpleExportRspElement() |
|
// |
|
// <!ELEMENT SIMPLEEXPRSP (METHODRESPONSE|EXPMETHODRESPONSE)> |
|
// |
|
//------------------------------------------------------------------------------ |
|
|
|
Array<Sint8> XmlWriter::formatSimpleExportRspElement( |
|
const Array<Sint8>& body) |
|
{ |
|
Array<Sint8> out; |
|
return out << "<SIMPLEEXPRSP>\n" << body << "</SIMPLEEXPRSP>\n"; |
|
} |
|
|
|
//------------------------------------------------------------------------------ |
|
// |
|
// formatIMethodResponseElement() |
|
// |
|
// <!ELEMENT EXPMETHODRESPONSE (ERROR|IRETURNVALUE?)> |
|
// <!ATTLIST EXPMETHODRESPONSE %CIMName;> |
|
// |
|
//------------------------------------------------------------------------------ |
|
|
|
Array<Sint8> XmlWriter::formatEMethodResponseElement( |
|
const char* name, |
|
const Array<Sint8>& body) |
|
{ |
|
Array<Sint8> out; |
|
out << "<EXPMETHODRESPONSE NAME=\"" << name << "\">\n"; |
|
out << body; |
|
out << "</EXPMETHODRESPONSE>\n"; |
|
return out; |
|
} |
|
|
|
//------------------------------------------------------------------------------ |
|
// |
|
// formatMethodResponseHeader() |
|
// |
|
// Build HTTP response header. |
|
// |
|
//------------------------------------------------------------------------------ |
|
|
|
Array<Sint8> XmlWriter::formatEMethodResponseHeader( |
|
const Array<Sint8>& content) |
|
{ |
|
Array<Sint8> out; |
|
out.reserve(1024); |
|
char nn[] = { '0' + (rand() % 10), '0' + (rand() % 10), '\0' }; |
|
|
|
out << "HTTP/1.1 200 OK\r\n"; |
|
out << "Content-CIMType: application/xml; charset=\"utf-8\"\r\n"; |
|
out << "Content-Length: " << content.size() << "\r\n"; |
|
out << "Ext:\r\n"; |
|
out << "Cache-Control: no-cache\r\n"; |
|
out << "Man: http://www.dmtf.org/cim/mapping/http/v1.0; ns="; |
|
out << nn <<"\r\n"; |
|
out << nn << "-CIMExport: MethodResponse\r\n\r\n"; |
|
out << content; |
|
return out; |
|
} |
|
|
|
//------------------------------------------------------------------------------ |
|
// |
|
// XmlWriter::formatSimpleMethodReqMessage() |
|
// |
|
//------------------------------------------------------------------------------ |
|
|
|
Array<Sint8> XmlWriter::formatSimpleMethodReqMessage( |
|
const char* host, |
|
const String& nameSpace, |
|
const char* iMethodName, |
|
const String& messageId, |
|
const String& authenticationHeader, |
|
const Array<Sint8>& body) |
|
{ |
|
return XmlWriter::formatMPostHeader( |
|
host, |
|
"MethodCall", |
|
iMethodName, |
|
nameSpace, |
|
authenticationHeader, |
|
XmlWriter::formatMessageElement( |
|
messageId, |
|
XmlWriter::formatSimpleReqElement( |
|
XmlWriter::formatMethodCallElement( |
|
iMethodName, |
|
nameSpace, |
|
body)))); |
|
} |
|
|
|
//------------------------------------------------------------------------------ |
|
// |
|
// formatMethodCallElement() |
|
// |
|
// <!ELEMENT METHODCALL (LOCALNAMESPACEPATH,IPARAMVALUE*)> |
|
// <!ATTLIST METHODCALL %CIMName;> |
|
// | // |
//------------------------------------------------------------------------------ | //------------------------------------------------------------------------------ |
|
const char* XmlWriter::keyBindingTypeToString (CIMKeyBinding::Type type) |
Array<Sint8> XmlWriter::formatMethodCallElement( |
|
const char* name, |
|
const String& nameSpace, |
|
const Array<Sint8>& iParamValues) |
|
{ |
|
Array<Sint8> out; |
|
out << "<METHODCALL NAME=\"" << name << "\">\n"; |
|
out << iParamValues; |
|
out << "</METHODCALL>\n"; |
|
return out; |
|
} |
|
|
|
Array<Sint8> XmlWriter::formatSimpleMethodRspMessage( |
|
const char* iMethodName, |
|
const String& messageId, |
|
const Array<Sint8>& body) |
|
{ | { |
return XmlWriter::formatMethodResponseHeader( |
switch (type) |
XmlWriter::formatMessageElement( |
|
messageId, |
|
XmlWriter::formatSimpleRspElement( |
|
XmlWriter::formatMethodResponseElement( |
|
iMethodName, |
|
body)))); |
|
} |
|
|
|
//------------------------------------------------------------------------------ |
|
// |
|
// formatMethodResponseElement() |
|
// |
|
// <!ELEMENT METHODRESPONSE (ERROR|IRETURNVALUE?)> |
|
// <!ATTLIST METHODRESPONSE %CIMName;> |
|
// |
|
//------------------------------------------------------------------------------ |
|
|
|
Array<Sint8> XmlWriter::formatMethodResponseElement( |
|
const char* name, |
|
const Array<Sint8>& body) |
|
{ | { |
Array<Sint8> out; |
case CIMKeyBinding::BOOLEAN: |
out << "<METHODRESPONSE NAME=\"" << name << "\">\n"; |
return "boolean"; |
out << body; |
|
out << "</METHODRESPONSE>\n"; |
|
return out; |
|
} |
|
|
|
//------------------------------------------------------------------------------ |
|
// |
|
// appendReturnValueElement() |
|
// |
|
// <!ELEMENT RETURNVALUE (VALUE|VALUE.REFERENCE)> |
|
// <!ATTLIST RETURNVALUE |
|
// %ParamType;> |
|
// |
|
//------------------------------------------------------------------------------ |
|
| |
Array<Sint8>& XmlWriter::appendReturnValueElement( |
case CIMKeyBinding::STRING: |
Array<Sint8>& out, |
return "string"; |
const CIMValue& value) |
|
{ |
|
out << "<RETURNVALUE"; |
|
| |
CIMType type = value.getType(); |
case CIMKeyBinding::NUMERIC: |
if (type != CIMType::NONE) |
return "numeric"; |
{ |
|
out << " PARAMTYPE=\"" << TypeToString(type) << "\""; |
|
} |
|
| |
out << ">\n"; |
case CIMKeyBinding::REFERENCE: |
value.toXml(out); |
default: |
out << "</RETURNVALUE>\n"; |
PEGASUS_ASSERT(false); |
return out; |
|
} | } |
| |
//------------------------------------------------------------------------------ |
return "unknown"; |
// |
|
// formatUnauthorizedResponseHeader() |
|
// |
|
// Build HTTP authentication response header for unauthorized requests. |
|
// |
|
// Returns unauthorized message in the following format: |
|
// |
|
// HTTP/1.1 401 Unauthorized |
|
// WWW-Authenticate: Basic "hostname:80" |
|
// <HTML><HEAD> |
|
// <TITLE>401 Unauthorized</TITLE> |
|
// </HEAD><BODY BGCOLOR="#99cc99"> |
|
// <H2>TEST401 Unauthorized</H2> |
|
// <HR> |
|
// </BODY></HTML> |
|
// |
|
//------------------------------------------------------------------------------ |
|
|
|
Array<Sint8> XmlWriter::formatUnauthorizedResponseHeader( |
|
const String& content) |
|
{ |
|
Array<Sint8> out; |
|
out.reserve(1024); |
|
|
|
out << "HTTP/1.1 401 Unauthorized\r\n"; |
|
out << content << "\r\n"; |
|
out << "\r\n"; |
|
|
|
//ATTN: We may need to include the following line, so that the browsers |
|
// can display the error message. |
|
// out << "<HTML><HEAD>\r\n"; |
|
// out << "<TITLE>" << "401 Unauthorized" << "</TITLE>\r\n"; |
|
// out << "</HEAD><BODY BGCOLOR=\"#99cc99\">\r\n"; |
|
// out << "<H2>TEST" << "401 Unauthorized" << "</H2>\r\n"; |
|
// out << "<HR>\r\n"; |
|
// out << "</BODY></HTML>\r\n"; |
|
|
|
return out; |
|
} | } |
| |
PEGASUS_NAMESPACE_END | PEGASUS_NAMESPACE_END |