/*
- * Copyright 2001-2006 Internet2
- *
+ * Copyright 2001-2007 Internet2
+ *
* Licensed under the Apache License, Version 2.0 (the "License");
* you may not use this file except in compliance with the License.
* You may obtain a copy of the License at
/**
* MetadataImpl.cpp
- *
+ *
* Implementation classes for SAML 2.0 Assertions schema
*/
#include "saml2/metadata/Metadata.h"
#include <xmltooling/AbstractComplexElement.h>
-#include <xmltooling/AbstractElementProxy.h>
#include <xmltooling/AbstractSimpleElement.h>
#include <xmltooling/impl/AnyElement.h>
#include <xmltooling/io/AbstractXMLObjectMarshaller.h>
#include <ctime>
#include <xercesc/util/XMLUniDefs.hpp>
+using namespace samlconstants;
using namespace opensaml::saml2md;
using namespace opensaml::saml2;
using namespace opensaml;
using namespace xmlsignature;
using namespace xmltooling;
using namespace std;
+using xmlconstants::XMLSIG_NS;
+using xmlconstants::XML_BOOL_NULL;
#if defined (_MSC_VER)
#pragma warning( push )
void init() {
m_Lang=NULL;
}
-
+
protected:
localizedNameTypeImpl() {
init();
}
-
+
public:
virtual ~localizedNameTypeImpl() {
XMLString::release(&m_Lang);
}
-
+
localizedNameTypeImpl(const XMLCh* nsURI, const XMLCh* localName, const XMLCh* prefix, const QName* schemaType)
: AbstractXMLObject(nsURI, localName, prefix, schemaType) {
init();
}
-
+
localizedNameTypeImpl(const localizedNameTypeImpl& src)
: AbstractXMLObject(src), AbstractSimpleElement(src), AbstractDOMCachingXMLObject(src) {
init();
setLang(src.getLang());
}
-
+
IMPL_XMLOBJECT_CLONE(localizedNameType);
IMPL_STRING_ATTRIB(Lang);
-
+
protected:
void marshallAttributes(DOMElement* domElement) const {
- MARSHALL_STRING_ATTRIB(Lang,LANG,XMLConstants::XML_NS);
+ MARSHALL_STRING_ATTRIB(Lang,LANG,xmlconstants::XML_NS);
}
void processAttribute(const DOMAttr* attribute) {
- PROC_STRING_ATTRIB(Lang,LANG,XMLConstants::XML_NS);
+ PROC_STRING_ATTRIB(Lang,LANG,xmlconstants::XML_NS);
AbstractXMLObjectUnmarshaller::processAttribute(attribute);
}
};
void init() {
m_Lang=NULL;
}
-
+
protected:
localizedURITypeImpl() {
init();
}
-
+
public:
virtual ~localizedURITypeImpl() {
XMLString::release(&m_Lang);
}
-
+
localizedURITypeImpl(const XMLCh* nsURI, const XMLCh* localName, const XMLCh* prefix, const QName* schemaType)
: AbstractXMLObject(nsURI, localName, prefix, schemaType) {
init();
}
-
+
localizedURITypeImpl(const localizedURITypeImpl& src)
: AbstractXMLObject(src), AbstractSimpleElement(src), AbstractDOMCachingXMLObject(src) {
init();
setLang(src.getLang());
}
-
+
IMPL_XMLOBJECT_CLONE(localizedURIType);
IMPL_STRING_ATTRIB(Lang);
-
+
protected:
void marshallAttributes(DOMElement* domElement) const {
- MARSHALL_STRING_ATTRIB(Lang,LANG,XMLConstants::XML_NS);
+ MARSHALL_STRING_ATTRIB(Lang,LANG,xmlconstants::XML_NS);
}
void processAttribute(const DOMAttr* attribute) {
- PROC_STRING_ATTRIB(Lang,LANG,XMLConstants::XML_NS);
+ PROC_STRING_ATTRIB(Lang,LANG,xmlconstants::XML_NS);
AbstractXMLObjectUnmarshaller::processAttribute(attribute);
}
};
{
public:
virtual ~OrganizationNameImpl() {}
-
+
OrganizationNameImpl(const XMLCh* nsURI, const XMLCh* localName, const XMLCh* prefix, const QName* schemaType)
: AbstractXMLObject(nsURI, localName, prefix, schemaType) {}
-
+
OrganizationNameImpl(const OrganizationNameImpl& src) : AbstractXMLObject(src), localizedNameTypeImpl(src) {}
-
+
IMPL_XMLOBJECT_CLONE(OrganizationName);
localizedNameType* clonelocalizedNameType() const {
return new OrganizationNameImpl(*this);
}
};
-
+
class SAML_DLLLOCAL OrganizationDisplayNameImpl : public virtual OrganizationDisplayName, public localizedNameTypeImpl
{
public:
virtual ~OrganizationDisplayNameImpl() {}
-
+
OrganizationDisplayNameImpl(const XMLCh* nsURI, const XMLCh* localName, const XMLCh* prefix, const QName* schemaType)
: AbstractXMLObject(nsURI, localName, prefix, schemaType) {}
-
+
OrganizationDisplayNameImpl(const OrganizationDisplayNameImpl& src) : AbstractXMLObject(src), localizedNameTypeImpl(src) {}
-
+
IMPL_XMLOBJECT_CLONE(OrganizationDisplayName);
localizedNameType* clonelocalizedNameType() const {
return new OrganizationDisplayNameImpl(*this);
{
public:
virtual ~OrganizationURLImpl() {}
-
+
OrganizationURLImpl(const XMLCh* nsURI, const XMLCh* localName, const XMLCh* prefix, const QName* schemaType)
: AbstractXMLObject(nsURI, localName, prefix, schemaType) {}
-
+
OrganizationURLImpl(const OrganizationURLImpl& src) : AbstractXMLObject(src), localizedURITypeImpl(src) {}
-
+
IMPL_XMLOBJECT_CLONE(OrganizationURL);
localizedURIType* clonelocalizedURIType() const {
return new OrganizationURLImpl(*this);
{
public:
virtual ~ServiceNameImpl() {}
-
+
ServiceNameImpl(const XMLCh* nsURI, const XMLCh* localName, const XMLCh* prefix, const QName* schemaType)
: AbstractXMLObject(nsURI, localName, prefix, schemaType) {}
-
+
ServiceNameImpl(const ServiceNameImpl& src) : AbstractXMLObject(src), localizedNameTypeImpl(src) {}
-
+
IMPL_XMLOBJECT_CLONE(ServiceName);
localizedNameType* clonelocalizedNameType() const {
return new ServiceNameImpl(*this);
{
public:
virtual ~ServiceDescriptionImpl() {}
-
+
ServiceDescriptionImpl(const XMLCh* nsURI, const XMLCh* localName, const XMLCh* prefix, const QName* schemaType)
: AbstractXMLObject(nsURI, localName, prefix, schemaType) {}
-
+
ServiceDescriptionImpl(const ServiceDescriptionImpl& src) : AbstractXMLObject(src), localizedNameTypeImpl(src) {}
-
+
IMPL_XMLOBJECT_CLONE(ServiceDescription);
localizedNameType* clonelocalizedNameType() const {
return new ServiceDescriptionImpl(*this);
};
class SAML_DLLLOCAL ExtensionsImpl : public virtual Extensions,
- public AbstractElementProxy,
+ public AbstractComplexElement,
public AbstractDOMCachingXMLObject,
public AbstractXMLObjectMarshaller,
public AbstractXMLObjectUnmarshaller
{
public:
virtual ~ExtensionsImpl() {}
-
+
ExtensionsImpl(const XMLCh* nsURI, const XMLCh* localName, const XMLCh* prefix, const QName* schemaType)
: AbstractXMLObject(nsURI, localName, prefix, schemaType) {
}
-
+
ExtensionsImpl(const ExtensionsImpl& src)
- : AbstractXMLObject(src), AbstractElementProxy(src), AbstractDOMCachingXMLObject(src) {
- for (list<XMLObject*>::const_iterator i=src.m_children.begin(); i!=src.m_children.end(); i++) {
- if (*i) {
- getXMLObjects().push_back((*i)->clone());
- }
- }
+ : AbstractXMLObject(src), AbstractComplexElement(src), AbstractDOMCachingXMLObject(src) {
+ VectorOf(XMLObject) v=getUnknownXMLObjects();
+ for (vector<XMLObject*>::const_iterator i=src.m_UnknownXMLObjects.begin(); i!=src.m_UnknownXMLObjects.end(); ++i)
+ v.push_back((*i)->clone());
}
-
+
IMPL_XMLOBJECT_CLONE(Extensions);
-
+ IMPL_XMLOBJECT_CHILDREN(UnknownXMLObject,m_children.end());
+
protected:
void processChildElement(XMLObject* childXMLObject, const DOMElement* root) {
// Unknown child.
const XMLCh* nsURI=root->getNamespaceURI();
- if (!XMLString::equals(nsURI,SAMLConstants::SAML20MD_NS) && nsURI && *nsURI) {
- getXMLObjects().push_back(childXMLObject);
+ if (!XMLString::equals(nsURI,SAML20MD_NS) && nsURI && *nsURI) {
+ getUnknownXMLObjects().push_back(childXMLObject);
return;
}
-
+
AbstractXMLObjectUnmarshaller::processChildElement(childXMLObject,root);
}
};
{
list<XMLObject*>::iterator m_pos_OrganizationDisplayName;
list<XMLObject*>::iterator m_pos_OrganizationURL;
-
+
void init() {
m_children.push_back(NULL);
m_children.push_back(NULL);
}
public:
virtual ~OrganizationImpl() {}
-
+
OrganizationImpl(const XMLCh* nsURI, const XMLCh* localName, const XMLCh* prefix, const QName* schemaType)
: AbstractXMLObject(nsURI, localName, prefix, schemaType) {
init();
}
-
+
OrganizationImpl(const OrganizationImpl& src)
: AbstractXMLObject(src), AbstractComplexElement(src),
AbstractAttributeExtensibleXMLObject(src), AbstractDOMCachingXMLObject(src) {
}
}
}
-
+
IMPL_XMLOBJECT_CLONE(Organization);
IMPL_TYPED_CHILD(Extensions);
IMPL_TYPED_CHILDREN(OrganizationName,m_pos_OrganizationDisplayName);
IMPL_TYPED_CHILDREN(OrganizationDisplayName,m_pos_OrganizationURL);
IMPL_TYPED_CHILDREN(OrganizationURL,m_children.end());
-
+
protected:
void marshallAttributes(DOMElement* domElement) const {
marshallExtensionAttributes(domElement);
}
void processChildElement(XMLObject* childXMLObject, const DOMElement* root) {
- PROC_TYPED_CHILD(Extensions,SAMLConstants::SAML20MD_NS,false);
- PROC_TYPED_CHILDREN(OrganizationName,SAMLConstants::SAML20MD_NS,false);
- PROC_TYPED_CHILDREN(OrganizationDisplayName,SAMLConstants::SAML20MD_NS,false);
- PROC_TYPED_CHILDREN(OrganizationURL,SAMLConstants::SAML20MD_NS,false);
+ PROC_TYPED_CHILD(Extensions,SAML20MD_NS,false);
+ PROC_TYPED_CHILDREN(OrganizationName,SAML20MD_NS,false);
+ PROC_TYPED_CHILDREN(OrganizationDisplayName,SAML20MD_NS,false);
+ PROC_TYPED_CHILDREN(OrganizationURL,SAML20MD_NS,false);
AbstractXMLObjectUnmarshaller::processChildElement(childXMLObject,root);
}
public AbstractXMLObjectUnmarshaller
{
list<XMLObject*>::iterator m_pos_TelephoneNumber;
-
+
void init() {
m_ContactType=NULL;
m_children.push_back(NULL);
}
public:
virtual ~ContactPersonImpl() {}
-
+
ContactPersonImpl(const XMLCh* nsURI, const XMLCh* localName, const XMLCh* prefix, const QName* schemaType)
: AbstractXMLObject(nsURI, localName, prefix, schemaType) {
init();
}
-
+
ContactPersonImpl(const ContactPersonImpl& src)
: AbstractXMLObject(src), AbstractComplexElement(src),
AbstractAttributeExtensibleXMLObject(src), AbstractDOMCachingXMLObject(src) {
setGivenName(src.getGivenName()->cloneGivenName());
if (src.getSurName())
setSurName(src.getSurName()->cloneSurName());
-
+
VectorOf(EmailAddress) v=getEmailAddresss();
for (vector<EmailAddress*>::const_iterator i=src.m_EmailAddresss.begin(); i!=src.m_EmailAddresss.end(); i++) {
if (*i) {
}
}
}
-
+
IMPL_XMLOBJECT_CLONE(ContactPerson);
IMPL_STRING_ATTRIB(ContactType);
IMPL_TYPED_CHILD(Extensions);
IMPL_TYPED_CHILD(SurName);
IMPL_TYPED_CHILDREN(EmailAddress,m_pos_TelephoneNumber);
IMPL_TYPED_CHILDREN(TelephoneNumber,m_children.end());
-
+
void setAttribute(const QName& qualifiedName, const XMLCh* value, bool ID=false) {
if (!qualifiedName.hasNamespaceURI()) {
if (XMLString::equals(qualifiedName.getLocalPart(),CONTACTTYPE_ATTRIB_NAME)) {
}
void processChildElement(XMLObject* childXMLObject, const DOMElement* root) {
- PROC_TYPED_CHILD(Extensions,SAMLConstants::SAML20MD_NS,false);
- PROC_TYPED_CHILD(Company,SAMLConstants::SAML20MD_NS,false);
- PROC_TYPED_CHILD(GivenName,SAMLConstants::SAML20MD_NS,false);
- PROC_TYPED_CHILD(SurName,SAMLConstants::SAML20MD_NS,false);
- PROC_TYPED_CHILDREN(EmailAddress,SAMLConstants::SAML20MD_NS,false);
- PROC_TYPED_CHILDREN(TelephoneNumber,SAMLConstants::SAML20MD_NS,false);
+ PROC_TYPED_CHILD(Extensions,SAML20MD_NS,false);
+ PROC_TYPED_CHILD(Company,SAML20MD_NS,false);
+ PROC_TYPED_CHILD(GivenName,SAML20MD_NS,false);
+ PROC_TYPED_CHILD(SurName,SAML20MD_NS,false);
+ PROC_TYPED_CHILDREN(EmailAddress,SAML20MD_NS,false);
+ PROC_TYPED_CHILDREN(TelephoneNumber,SAML20MD_NS,false);
AbstractXMLObjectUnmarshaller::processChildElement(childXMLObject,root);
}
void init() {
m_Namespace=NULL;
}
-
+
public:
virtual ~AdditionalMetadataLocationImpl() {
XMLString::release(&m_Namespace);
}
-
+
AdditionalMetadataLocationImpl(const XMLCh* nsURI, const XMLCh* localName, const XMLCh* prefix, const QName* schemaType)
: AbstractXMLObject(nsURI, localName, prefix, schemaType) {
init();
}
-
+
AdditionalMetadataLocationImpl(const AdditionalMetadataLocationImpl& src)
: AbstractXMLObject(src), AbstractSimpleElement(src), AbstractDOMCachingXMLObject(src) {
init();
}
-
+
IMPL_XMLOBJECT_CLONE(AdditionalMetadataLocation);
IMPL_STRING_ATTRIB(Namespace);
-
+
protected:
void marshallAttributes(DOMElement* domElement) const {
MARSHALL_STRING_ATTRIB(Namespace,NAMESPACE,NULL);
virtual ~KeyDescriptorImpl() {
XMLString::release(&m_Use);
}
-
+
KeyDescriptorImpl(const XMLCh* nsURI, const XMLCh* localName, const XMLCh* prefix, const QName* schemaType)
: AbstractXMLObject(nsURI, localName, prefix, schemaType) {
init();
}
-
+
KeyDescriptorImpl(const KeyDescriptorImpl& src)
: AbstractXMLObject(src), AbstractComplexElement(src), AbstractDOMCachingXMLObject(src) {
init();
}
}
}
-
+
IMPL_XMLOBJECT_CLONE(KeyDescriptor);
IMPL_STRING_ATTRIB(Use);
IMPL_TYPED_FOREIGN_CHILD(KeyInfo,xmlsignature);
IMPL_TYPED_FOREIGN_CHILDREN(EncryptionMethod,xmlencryption,m_children.end());
-
+
protected:
void marshallAttributes(DOMElement* domElement) const {
MARSHALL_STRING_ATTRIB(Use,USE,NULL);
}
void processChildElement(XMLObject* childXMLObject, const DOMElement* root) {
- PROC_TYPED_FOREIGN_CHILD(KeyInfo,xmlsignature,XMLConstants::XMLSIG_NS,false);
- PROC_TYPED_FOREIGN_CHILDREN(EncryptionMethod,xmlencryption,SAMLConstants::SAML20MD_NS,false);
+ PROC_TYPED_FOREIGN_CHILD(KeyInfo,xmlsignature,XMLSIG_NS,false);
+ PROC_TYPED_FOREIGN_CHILDREN(EncryptionMethod,xmlencryption,SAML20MD_NS,false);
AbstractXMLObjectUnmarshaller::processChildElement(childXMLObject,root);
}
};
class SAML_DLLLOCAL EndpointTypeImpl : public virtual EndpointType,
- public AbstractElementProxy,
public AbstractAttributeExtensibleXMLObject,
+ public AbstractComplexElement,
public AbstractDOMCachingXMLObject,
public AbstractXMLObjectMarshaller,
public AbstractXMLObjectUnmarshaller
void init() {
m_Binding=m_Location=m_ResponseLocation=NULL;
}
-
+
protected:
EndpointTypeImpl() {
init();
}
-
+
public:
virtual ~EndpointTypeImpl() {
XMLString::release(&m_Binding);
XMLString::release(&m_Location);
XMLString::release(&m_ResponseLocation);
}
-
+
EndpointTypeImpl(const XMLCh* nsURI, const XMLCh* localName, const XMLCh* prefix, const QName* schemaType)
: AbstractXMLObject(nsURI, localName, prefix, schemaType) {
}
-
+
EndpointTypeImpl(const EndpointTypeImpl& src)
- : AbstractXMLObject(src), AbstractElementProxy(src),
- AbstractAttributeExtensibleXMLObject(src), AbstractDOMCachingXMLObject(src) {
+ : AbstractXMLObject(src),
+ AbstractAttributeExtensibleXMLObject(src),
+ AbstractComplexElement(src),
+ AbstractDOMCachingXMLObject(src) {
setBinding(src.getBinding());
setLocation(src.getLocation());
setResponseLocation(src.getResponseLocation());
- for (list<XMLObject*>::const_iterator i=src.m_children.begin(); i!=src.m_children.end(); i++) {
- if (*i) {
- getXMLObjects().push_back((*i)->clone());
- }
- }
+ VectorOf(XMLObject) v=getUnknownXMLObjects();
+ for (vector<XMLObject*>::const_iterator i=src.m_UnknownXMLObjects.begin(); i!=src.m_UnknownXMLObjects.end(); ++i)
+ v.push_back((*i)->clone());
}
-
+
IMPL_XMLOBJECT_CLONE(EndpointType);
IMPL_STRING_ATTRIB(Binding);
IMPL_STRING_ATTRIB(Location);
IMPL_STRING_ATTRIB(ResponseLocation);
-
+ IMPL_XMLOBJECT_CHILDREN(UnknownXMLObject,m_children.end());
+
void setAttribute(const QName& qualifiedName, const XMLCh* value, bool ID=false) {
if (!qualifiedName.hasNamespaceURI()) {
if (XMLString::equals(qualifiedName.getLocalPart(),BINDING_ATTRIB_NAME)) {
void processChildElement(XMLObject* childXMLObject, const DOMElement* root) {
// Unknown child.
const XMLCh* nsURI=root->getNamespaceURI();
- if (!XMLString::equals(nsURI,SAMLConstants::SAML20MD_NS) && nsURI && *nsURI) {
- getXMLObjects().push_back(childXMLObject);
+ if (!XMLString::equals(nsURI,SAML20MD_NS) && nsURI && *nsURI) {
+ getUnknownXMLObjects().push_back(childXMLObject);
return;
}
AbstractXMLObjectUnmarshaller::processChildElement(childXMLObject,root);
{
void init() {
m_Index=NULL;
- m_isDefault=XMLConstants::XML_BOOL_NULL;
+ m_isDefault=XML_BOOL_NULL;
}
-
+
protected:
IndexedEndpointTypeImpl() {
init();
virtual ~IndexedEndpointTypeImpl() {
XMLString::release(&m_Index);
}
-
+
IndexedEndpointTypeImpl(const XMLCh* nsURI, const XMLCh* localName, const XMLCh* prefix, const QName* schemaType)
: AbstractXMLObject(nsURI, localName, prefix, schemaType) {}
-
+
IndexedEndpointTypeImpl(const IndexedEndpointTypeImpl& src) : AbstractXMLObject(src), EndpointTypeImpl(src) {
setIndex(src.m_Index);
isDefault(src.m_isDefault);
}
-
+
IMPL_XMLOBJECT_CLONE(IndexedEndpointType);
EndpointType* cloneEndpointType() const {
return new IndexedEndpointTypeImpl(*this);
}
-
+
IMPL_INTEGER_ATTRIB(Index);
IMPL_BOOLEAN_ATTRIB(isDefault);
}
EndpointTypeImpl::setAttribute(qualifiedName, value, ID);
}
-
+
protected:
void marshallAttributes(DOMElement* domElement) const {
MARSHALL_INTEGER_ATTRIB(Index,INDEX,NULL);
{
public:
virtual ~ArtifactResolutionServiceImpl() {}
-
+
ArtifactResolutionServiceImpl(const XMLCh* nsURI, const XMLCh* localName, const XMLCh* prefix, const QName* schemaType)
: AbstractXMLObject(nsURI, localName, prefix, schemaType) {}
-
+
ArtifactResolutionServiceImpl(const ArtifactResolutionServiceImpl& src) : AbstractXMLObject(src), IndexedEndpointTypeImpl(src) {}
-
+
IMPL_XMLOBJECT_CLONE(ArtifactResolutionService);
IndexedEndpointType* cloneIndexedEndpointType() const {
return new ArtifactResolutionServiceImpl(*this);
{
public:
virtual ~SingleLogoutServiceImpl() {}
-
+
SingleLogoutServiceImpl(const XMLCh* nsURI, const XMLCh* localName, const XMLCh* prefix, const QName* schemaType)
: AbstractXMLObject(nsURI, localName, prefix, schemaType) {}
-
+
SingleLogoutServiceImpl(const SingleLogoutServiceImpl& src) : AbstractXMLObject(src), EndpointTypeImpl(src) {}
-
+
IMPL_XMLOBJECT_CLONE(SingleLogoutService);
EndpointType* cloneEndpointType() const {
return new SingleLogoutServiceImpl(*this);
{
public:
virtual ~ManageNameIDServiceImpl() {}
-
+
ManageNameIDServiceImpl(const XMLCh* nsURI, const XMLCh* localName, const XMLCh* prefix, const QName* schemaType)
: AbstractXMLObject(nsURI, localName, prefix, schemaType) {}
-
+
ManageNameIDServiceImpl(const ManageNameIDServiceImpl& src) : AbstractXMLObject(src), EndpointTypeImpl(src) {}
-
+
IMPL_XMLOBJECT_CLONE(ManageNameIDService);
EndpointType* cloneEndpointType() const {
return new ManageNameIDServiceImpl(*this);
{
public:
virtual ~SingleSignOnServiceImpl() {}
-
+
SingleSignOnServiceImpl(const XMLCh* nsURI, const XMLCh* localName, const XMLCh* prefix, const QName* schemaType)
: AbstractXMLObject(nsURI, localName, prefix, schemaType) {}
-
+
SingleSignOnServiceImpl(const SingleSignOnServiceImpl& src) : AbstractXMLObject(src), EndpointTypeImpl(src) {}
-
+
IMPL_XMLOBJECT_CLONE(SingleSignOnService);
EndpointType* cloneEndpointType() const {
return new SingleSignOnServiceImpl(*this);
{
public:
virtual ~NameIDMappingServiceImpl() {}
-
+
NameIDMappingServiceImpl(const XMLCh* nsURI, const XMLCh* localName, const XMLCh* prefix, const QName* schemaType)
: AbstractXMLObject(nsURI, localName, prefix, schemaType) {}
-
+
NameIDMappingServiceImpl(const NameIDMappingServiceImpl& src) : AbstractXMLObject(src), EndpointTypeImpl(src) {}
-
+
IMPL_XMLOBJECT_CLONE(NameIDMappingService);
EndpointType* cloneEndpointType() const {
return new NameIDMappingServiceImpl(*this);
}
};
-
+
class SAML_DLLLOCAL AssertionIDRequestServiceImpl : public virtual AssertionIDRequestService, public EndpointTypeImpl
{
public:
virtual ~AssertionIDRequestServiceImpl() {}
-
+
AssertionIDRequestServiceImpl(const XMLCh* nsURI, const XMLCh* localName, const XMLCh* prefix, const QName* schemaType)
: AbstractXMLObject(nsURI, localName, prefix, schemaType) {}
-
+
AssertionIDRequestServiceImpl(const AssertionIDRequestServiceImpl& src) : AbstractXMLObject(src), EndpointTypeImpl(src) {}
-
+
IMPL_XMLOBJECT_CLONE(AssertionIDRequestService);
EndpointType* cloneEndpointType() const {
return new AssertionIDRequestServiceImpl(*this);
{
public:
virtual ~AssertionConsumerServiceImpl() {}
-
+
AssertionConsumerServiceImpl(const XMLCh* nsURI, const XMLCh* localName, const XMLCh* prefix, const QName* schemaType)
: AbstractXMLObject(nsURI, localName, prefix, schemaType) {}
-
+
AssertionConsumerServiceImpl(const AssertionConsumerServiceImpl& src) : AbstractXMLObject(src), IndexedEndpointTypeImpl(src) {}
-
+
IMPL_XMLOBJECT_CLONE(AssertionConsumerService);
EndpointType* cloneEndpointType() const {
return new AssertionConsumerServiceImpl(*this);
{
public:
virtual ~AuthnQueryServiceImpl() {}
-
+
AuthnQueryServiceImpl(const XMLCh* nsURI, const XMLCh* localName, const XMLCh* prefix, const QName* schemaType)
: AbstractXMLObject(nsURI, localName, prefix, schemaType) {}
-
+
AuthnQueryServiceImpl(const AuthnQueryServiceImpl& src) : AbstractXMLObject(src), EndpointTypeImpl(src) {}
-
+
IMPL_XMLOBJECT_CLONE(AuthnQueryService);
EndpointType* cloneEndpointType() const {
return new AuthnQueryServiceImpl(*this);
{
public:
virtual ~AuthzServiceImpl() {}
-
+
AuthzServiceImpl(const XMLCh* nsURI, const XMLCh* localName, const XMLCh* prefix, const QName* schemaType)
: AbstractXMLObject(nsURI, localName, prefix, schemaType) {}
-
+
AuthzServiceImpl(const AuthzServiceImpl& src) : AbstractXMLObject(src), EndpointTypeImpl(src) {}
-
+
IMPL_XMLOBJECT_CLONE(AuthzService);
EndpointType* cloneEndpointType() const {
return new AuthzServiceImpl(*this);
{
public:
virtual ~AttributeServiceImpl() {}
-
+
AttributeServiceImpl(const XMLCh* nsURI, const XMLCh* localName, const XMLCh* prefix, const QName* schemaType)
: AbstractXMLObject(nsURI, localName, prefix, schemaType) {}
-
+
AttributeServiceImpl(const AttributeServiceImpl& src) : AbstractXMLObject(src), EndpointTypeImpl(src) {}
-
+
IMPL_XMLOBJECT_CLONE(AttributeService);
EndpointType* cloneEndpointType() const {
return new AttributeServiceImpl(*this);
m_pos_ContactPerson=m_pos_Organization;
++m_pos_ContactPerson;
}
-
+
protected:
list<XMLObject*>::iterator m_pos_ContactPerson;
RoleDescriptorImpl() {
init();
}
-
+
public:
virtual ~RoleDescriptorImpl() {
XMLString::release(&m_ID);
delete m_ValidUntil;
delete m_CacheDuration;
}
-
+
RoleDescriptorImpl(const XMLCh* nsURI, const XMLCh* localName, const XMLCh* prefix, const QName* schemaType)
: AbstractXMLObject(nsURI, localName, prefix, schemaType) {
init();
}
-
+
RoleDescriptorImpl(const RoleDescriptorImpl& src)
: AbstractXMLObject(src), AbstractComplexElement(src),
AbstractAttributeExtensibleXMLObject(src), AbstractDOMCachingXMLObject(src) {
setExtensions(src.getExtensions()->cloneExtensions());
if (src.getOrganization())
setOrganization(src.getOrganization()->cloneOrganization());
-
+
VectorOf(KeyDescriptor) v=getKeyDescriptors();
for (vector<KeyDescriptor*>::const_iterator i=src.m_KeyDescriptors.begin(); i!=src.m_KeyDescriptors.end(); i++) {
if (*i) {
Signature* getSignature() const {
return m_Signature;
}
-
+
void setSignature(Signature* sig) {
prepareForAssignment(m_Signature,sig);
*m_pos_Signature=m_Signature=sig;
if (m_Signature)
m_Signature->setContentReference(new opensaml::ContentReference(*this));
}
-
+
IMPL_ID_ATTRIB(ID);
IMPL_STRING_ATTRIB(ProtocolSupportEnumeration);
IMPL_STRING_ATTRIB(ErrorURL);
IMPL_DATETIME_ATTRIB(ValidUntil,SAMLTIME_MAX);
- IMPL_DATETIME_ATTRIB(CacheDuration,0);
+ IMPL_DURATION_ATTRIB(CacheDuration,0);
IMPL_TYPED_CHILD(Extensions);
IMPL_TYPED_CHILDREN(KeyDescriptor,m_pos_Organization);
IMPL_TYPED_CHILD(Organization);
IMPL_TYPED_CHILDREN(ContactPerson,m_pos_ContactPerson);
bool hasSupport(const XMLCh* protocol) const {
+ if (!protocol || !*protocol)
+ return true;
if (m_ProtocolSupportEnumeration) {
// Look for first character.
unsigned int len=XMLString::stringLen(protocol);
}
return false;
}
-
+
+ void addSupport(const XMLCh* protocol) {
+ if (hasSupport(protocol))
+ return;
+ if (m_ProtocolSupportEnumeration && *m_ProtocolSupportEnumeration) {
+#ifdef HAVE_GOOD_STL
+ xstring pse(m_ProtocolSupportEnumeration);
+ pse = pse + chSpace + protocol;
+ setProtocolSupportEnumeration(pse.c_str());
+#else
+ auto_ptr_char temp(m_ProtocolSupportEnumeration);
+ auto_ptr_char temp2(protocol);
+ string pse(temp.get());
+ pse = pse + ' ' + temp2.get();
+ auto_ptr_XMLCh temp3(pse.c_str());
+ setProtocolSupportEnumeration(temp3.get());
+#endif
+ }
+ else {
+ setProtocolSupportEnumeration(protocol);
+ }
+ }
+
void setAttribute(const QName& qualifiedName, const XMLCh* value, bool ID=false) {
if (!qualifiedName.hasNamespaceURI()) {
if (XMLString::equals(qualifiedName.getLocalPart(),ID_ATTRIB_NAME)) {
}
void processChildElement(XMLObject* childXMLObject, const DOMElement* root) {
- PROC_TYPED_FOREIGN_CHILD(Signature,xmlsignature,XMLConstants::XMLSIG_NS,false);
- PROC_TYPED_CHILD(Extensions,SAMLConstants::SAML20MD_NS,false);
- PROC_TYPED_CHILDREN(KeyDescriptor,SAMLConstants::SAML20MD_NS,false);
- PROC_TYPED_CHILD(Organization,SAMLConstants::SAML20MD_NS,false);
- PROC_TYPED_CHILDREN(ContactPerson,SAMLConstants::SAML20MD_NS,false);
+ PROC_TYPED_FOREIGN_CHILD(Signature,xmlsignature,XMLSIG_NS,false);
+ PROC_TYPED_CHILD(Extensions,SAML20MD_NS,false);
+ PROC_TYPED_CHILDREN(KeyDescriptor,SAML20MD_NS,false);
+ PROC_TYPED_CHILD(Organization,SAML20MD_NS,false);
+ PROC_TYPED_CHILDREN(ContactPerson,SAML20MD_NS,false);
AbstractXMLObjectUnmarshaller::processChildElement(childXMLObject,root);
}
m_pos_NameIDFormat=m_pos_ManageNameIDService;
++m_pos_NameIDFormat;
}
-
+
protected:
list<XMLObject*>::iterator m_pos_ArtifactResolutionService;
list<XMLObject*>::iterator m_pos_SingleLogoutService;
list<XMLObject*>::iterator m_pos_ManageNameIDService;
list<XMLObject*>::iterator m_pos_NameIDFormat;
-
+
SSODescriptorTypeImpl() {
init();
}
-
+
public:
virtual ~SSODescriptorTypeImpl() {}
-
+
SSODescriptorTypeImpl(const XMLCh* nsURI, const XMLCh* localName, const XMLCh* prefix, const QName* schemaType)
: AbstractXMLObject(nsURI, localName, prefix, schemaType) {
init();
}
-
+
SSODescriptorTypeImpl(const SSODescriptorTypeImpl& src) : AbstractXMLObject(src), RoleDescriptorImpl(src) {
init();
VectorOf(ArtifactResolutionService) v=getArtifactResolutionServices();
}
}
}
-
+
IMPL_TYPED_CHILDREN(ArtifactResolutionService,m_pos_ArtifactResolutionService);
IMPL_TYPED_CHILDREN(SingleLogoutService,m_pos_SingleLogoutService);
IMPL_TYPED_CHILDREN(ManageNameIDService,m_pos_ManageNameIDService);
protected:
void processChildElement(XMLObject* childXMLObject, const DOMElement* root) {
- PROC_TYPED_CHILDREN(ArtifactResolutionService,SAMLConstants::SAML20MD_NS,false);
- PROC_TYPED_CHILDREN(SingleLogoutService,SAMLConstants::SAML20MD_NS,false);
- PROC_TYPED_CHILDREN(ManageNameIDService,SAMLConstants::SAML20MD_NS,false);
- PROC_TYPED_CHILDREN(NameIDFormat,SAMLConstants::SAML20MD_NS,false);
+ PROC_TYPED_CHILDREN(ArtifactResolutionService,SAML20MD_NS,false);
+ PROC_TYPED_CHILDREN(SingleLogoutService,SAML20MD_NS,false);
+ PROC_TYPED_CHILDREN(ManageNameIDService,SAML20MD_NS,false);
+ PROC_TYPED_CHILDREN(NameIDFormat,SAML20MD_NS,false);
RoleDescriptorImpl::processChildElement(childXMLObject,root);
}
};
list<XMLObject*>::iterator m_pos_NameIDMappingService;
list<XMLObject*>::iterator m_pos_AssertionIDRequestService;
list<XMLObject*>::iterator m_pos_AttributeProfile;
-
+
void init() {
- m_WantAuthnRequestsSigned=XMLConstants::XML_BOOL_NULL;
+ m_WantAuthnRequestsSigned=XML_BOOL_NULL;
m_children.push_back(NULL);
m_children.push_back(NULL);
m_children.push_back(NULL);
m_pos_AttributeProfile=m_pos_AssertionIDRequestService;
++m_pos_AttributeProfile;
}
-
+
public:
virtual ~IDPSSODescriptorImpl() {}
-
+
IDPSSODescriptorImpl(const XMLCh* nsURI, const XMLCh* localName, const XMLCh* prefix, const QName* schemaType)
: AbstractXMLObject(nsURI, localName, prefix, schemaType) {
init();
}
-
+
IDPSSODescriptorImpl(const IDPSSODescriptorImpl& src) : AbstractXMLObject(src), SSODescriptorTypeImpl(src) {
init();
WantAuthnRequestsSigned(src.m_WantAuthnRequestsSigned);
}
}
}
-
+
IMPL_XMLOBJECT_CLONE(IDPSSODescriptor);
SSODescriptorType* cloneSSODescriptorType() const {
return new IDPSSODescriptorImpl(*this);
RoleDescriptor* cloneRoleDescriptor() const {
return new IDPSSODescriptorImpl(*this);
}
-
+
IMPL_BOOLEAN_ATTRIB(WantAuthnRequestsSigned);
IMPL_TYPED_CHILDREN(SingleSignOnService,m_pos_SingleSignOnService);
IMPL_TYPED_CHILDREN(NameIDMappingService,m_pos_NameIDMappingService);
MARSHALL_BOOLEAN_ATTRIB(WantAuthnRequestsSigned,WANTAUTHNREQUESTSSIGNED,NULL);
RoleDescriptorImpl::marshallAttributes(domElement);
}
-
+
void processChildElement(XMLObject* childXMLObject, const DOMElement* root) {
- PROC_TYPED_CHILDREN(SingleSignOnService,SAMLConstants::SAML20MD_NS,false);
- PROC_TYPED_CHILDREN(NameIDMappingService,SAMLConstants::SAML20MD_NS,false);
- PROC_TYPED_CHILDREN(AssertionIDRequestService,SAMLConstants::SAML20MD_NS,false);
- PROC_TYPED_CHILDREN(AttributeProfile,SAMLConstants::SAML20MD_NS,false);
- PROC_TYPED_FOREIGN_CHILDREN(Attribute,saml2,SAMLConstants::SAML20_NS,false);
+ PROC_TYPED_CHILDREN(SingleSignOnService,SAML20MD_NS,false);
+ PROC_TYPED_CHILDREN(NameIDMappingService,SAML20MD_NS,false);
+ PROC_TYPED_CHILDREN(AssertionIDRequestService,SAML20MD_NS,false);
+ PROC_TYPED_CHILDREN(AttributeProfile,SAML20MD_NS,false);
+ PROC_TYPED_FOREIGN_CHILDREN(Attribute,saml2,SAML20_NS,false);
SSODescriptorTypeImpl::processChildElement(childXMLObject,root);
}
};
{
void init() {
m_Name=m_NameFormat=m_FriendlyName=NULL;
- m_isRequired=XMLConstants::XML_BOOL_NULL;
+ m_isRequired=XML_BOOL_NULL;
}
public:
virtual ~RequestedAttributeImpl() {
XMLString::release(&m_NameFormat);
XMLString::release(&m_FriendlyName);
}
-
+
RequestedAttributeImpl(const XMLCh* nsURI, const XMLCh* localName, const XMLCh* prefix, const QName* schemaType)
: AbstractXMLObject(nsURI, localName, prefix, schemaType) {
init();
}
-
+
RequestedAttributeImpl(const RequestedAttributeImpl& src)
: AbstractXMLObject(src), AbstractComplexElement(src),
AbstractAttributeExtensibleXMLObject(src), AbstractDOMCachingXMLObject(src) {
}
}
}
-
+
IMPL_XMLOBJECT_CLONE(RequestedAttribute);
Attribute* cloneAttribute() const {
return new RequestedAttributeImpl(*this);
}
-
+
IMPL_STRING_ATTRIB(Name);
IMPL_STRING_ATTRIB(NameFormat);
IMPL_STRING_ATTRIB(FriendlyName);
IMPL_BOOLEAN_ATTRIB(isRequired);
IMPL_XMLOBJECT_CHILDREN(AttributeValue,m_children.end());
-
+
void setAttribute(const QName& qualifiedName, const XMLCh* value, bool ID=false) {
if (!qualifiedName.hasNamespaceURI()) {
if (XMLString::equals(qualifiedName.getLocalPart(),NAME_ATTRIB_NAME)) {
{
list<XMLObject*>::iterator m_pos_ServiceDescription;
list<XMLObject*>::iterator m_pos_RequestedAttribute;
-
+
void init() {
m_Index=NULL;
- m_isDefault=XMLConstants::XML_BOOL_NULL;
+ m_isDefault=XML_BOOL_NULL;
m_children.push_back(NULL);
m_children.push_back(NULL);
m_pos_ServiceDescription=m_children.begin();
virtual ~AttributeConsumingServiceImpl() {
XMLString::release(&m_Index);
}
-
+
AttributeConsumingServiceImpl(const XMLCh* nsURI, const XMLCh* localName, const XMLCh* prefix, const QName* schemaType)
: AbstractXMLObject(nsURI, localName, prefix, schemaType) {
init();
}
-
+
AttributeConsumingServiceImpl(const AttributeConsumingServiceImpl& src)
: AbstractXMLObject(src), AbstractComplexElement(src), AbstractDOMCachingXMLObject(src) {
init();
}
}
}
-
+
IMPL_XMLOBJECT_CLONE(AttributeConsumingService);
IMPL_INTEGER_ATTRIB(Index);
IMPL_BOOLEAN_ATTRIB(isDefault);
IMPL_TYPED_CHILDREN(ServiceName,m_pos_ServiceDescription);
IMPL_TYPED_CHILDREN(ServiceDescription,m_pos_RequestedAttribute);
IMPL_TYPED_CHILDREN(RequestedAttribute,m_children.end());
-
+
protected:
void marshallAttributes(DOMElement* domElement) const {
MARSHALL_INTEGER_ATTRIB(Index,INDEX,NULL);
}
void processChildElement(XMLObject* childXMLObject, const DOMElement* root) {
- PROC_TYPED_CHILDREN(ServiceName,SAMLConstants::SAML20MD_NS,false);
- PROC_TYPED_CHILDREN(ServiceDescription,SAMLConstants::SAML20MD_NS,false);
- PROC_TYPED_CHILDREN(RequestedAttribute,SAMLConstants::SAML20MD_NS,false);
+ PROC_TYPED_CHILDREN(ServiceName,SAML20MD_NS,false);
+ PROC_TYPED_CHILDREN(ServiceDescription,SAML20MD_NS,false);
+ PROC_TYPED_CHILDREN(RequestedAttribute,SAML20MD_NS,false);
AbstractXMLObjectUnmarshaller::processChildElement(childXMLObject,root);
}
class SAML_DLLLOCAL SPSSODescriptorImpl : public virtual SPSSODescriptor, public SSODescriptorTypeImpl
{
list<XMLObject*>::iterator m_pos_AssertionConsumerService;
-
+
void init() {
- m_AuthnRequestsSigned=XMLConstants::XML_BOOL_NULL;
- m_WantAssertionsSigned=XMLConstants::XML_BOOL_NULL;
+ m_AuthnRequestsSigned=XML_BOOL_NULL;
+ m_WantAssertionsSigned=XML_BOOL_NULL;
m_children.push_back(NULL);
m_pos_AssertionConsumerService=m_pos_NameIDFormat;
++m_pos_AssertionConsumerService;
}
-
+
public:
virtual ~SPSSODescriptorImpl() {}
-
+
SPSSODescriptorImpl(const XMLCh* nsURI, const XMLCh* localName, const XMLCh* prefix, const QName* schemaType)
: AbstractXMLObject(nsURI, localName, prefix, schemaType) {
init();
}
-
+
SPSSODescriptorImpl(const SPSSODescriptorImpl& src) : AbstractXMLObject(src), SSODescriptorTypeImpl(src) {
init();
AuthnRequestsSigned(src.m_AuthnRequestsSigned);
}
}
}
-
+
IMPL_XMLOBJECT_CLONE(SPSSODescriptor);
SSODescriptorType* cloneSSODescriptorType() const {
return cloneSPSSODescriptor();
RoleDescriptor* cloneRoleDescriptor() const {
return cloneSPSSODescriptor();
}
-
+
IMPL_BOOLEAN_ATTRIB(AuthnRequestsSigned);
IMPL_BOOLEAN_ATTRIB(WantAssertionsSigned);
IMPL_TYPED_CHILDREN(AssertionConsumerService,m_pos_AssertionConsumerService);
MARSHALL_BOOLEAN_ATTRIB(WantAssertionsSigned,WANTASSERTIONSSIGNED,NULL);
RoleDescriptorImpl::marshallAttributes(domElement);
}
-
+
void processChildElement(XMLObject* childXMLObject, const DOMElement* root) {
- PROC_TYPED_CHILDREN(AssertionConsumerService,SAMLConstants::SAML20MD_NS,false);
- PROC_TYPED_CHILDREN(AttributeConsumingService,SAMLConstants::SAML20MD_NS,false);
+ PROC_TYPED_CHILDREN(AssertionConsumerService,SAML20MD_NS,false);
+ PROC_TYPED_CHILDREN(AttributeConsumingService,SAML20MD_NS,false);
SSODescriptorTypeImpl::processChildElement(childXMLObject,root);
}
};
{
list<XMLObject*>::iterator m_pos_AuthnQueryService;
list<XMLObject*>::iterator m_pos_AssertionIDRequestService;
-
+
void init() {
m_children.push_back(NULL);
m_children.push_back(NULL);
m_pos_AssertionIDRequestService=m_pos_AuthnQueryService;
++m_pos_AssertionIDRequestService;
}
-
+
public:
virtual ~AuthnAuthorityDescriptorImpl() {}
-
+
AuthnAuthorityDescriptorImpl(const XMLCh* nsURI, const XMLCh* localName, const XMLCh* prefix, const QName* schemaType)
: AbstractXMLObject(nsURI, localName, prefix, schemaType) {
init();
}
-
+
AuthnAuthorityDescriptorImpl(const AuthnAuthorityDescriptorImpl& src) : AbstractXMLObject(src), RoleDescriptorImpl(src) {
init();
VectorOf(AuthnQueryService) v=getAuthnQueryServices();
}
}
}
-
+
IMPL_XMLOBJECT_CLONE(AuthnAuthorityDescriptor);
RoleDescriptor* cloneRoleDescriptor() const {
return cloneAuthnAuthorityDescriptor();
}
-
+
IMPL_TYPED_CHILDREN(AuthnQueryService,m_pos_AuthnQueryService);
IMPL_TYPED_CHILDREN(AssertionIDRequestService,m_pos_AssertionIDRequestService);
IMPL_TYPED_CHILDREN(NameIDFormat,m_children.end());
protected:
void processChildElement(XMLObject* childXMLObject, const DOMElement* root) {
- PROC_TYPED_CHILDREN(AuthnQueryService,SAMLConstants::SAML20MD_NS,false);
- PROC_TYPED_CHILDREN(AssertionIDRequestService,SAMLConstants::SAML20MD_NS,false);
- PROC_TYPED_CHILDREN(NameIDFormat,SAMLConstants::SAML20MD_NS,false);
+ PROC_TYPED_CHILDREN(AuthnQueryService,SAML20MD_NS,false);
+ PROC_TYPED_CHILDREN(AssertionIDRequestService,SAML20MD_NS,false);
+ PROC_TYPED_CHILDREN(NameIDFormat,SAML20MD_NS,false);
RoleDescriptorImpl::processChildElement(childXMLObject,root);
}
};
{
list<XMLObject*>::iterator m_pos_AuthzService;
list<XMLObject*>::iterator m_pos_AssertionIDRequestService;
-
+
void init() {
m_children.push_back(NULL);
m_children.push_back(NULL);
m_pos_AssertionIDRequestService=m_pos_AuthzService;
++m_pos_AssertionIDRequestService;
}
-
+
public:
virtual ~PDPDescriptorImpl() {}
-
+
PDPDescriptorImpl(const XMLCh* nsURI, const XMLCh* localName, const XMLCh* prefix, const QName* schemaType)
: AbstractXMLObject(nsURI, localName, prefix, schemaType) {
init();
}
-
+
PDPDescriptorImpl(const PDPDescriptorImpl& src) : AbstractXMLObject(src), RoleDescriptorImpl(src) {
init();
VectorOf(AuthzService) v=getAuthzServices();
}
}
}
-
+
IMPL_XMLOBJECT_CLONE(PDPDescriptor);
RoleDescriptor* cloneRoleDescriptor() const {
return clonePDPDescriptor();
}
-
+
IMPL_TYPED_CHILDREN(AuthzService,m_pos_AuthzService);
IMPL_TYPED_CHILDREN(AssertionIDRequestService,m_pos_AssertionIDRequestService);
IMPL_TYPED_CHILDREN(NameIDFormat,m_children.end());
protected:
void processChildElement(XMLObject* childXMLObject, const DOMElement* root) {
- PROC_TYPED_CHILDREN(AuthzService,SAMLConstants::SAML20MD_NS,false);
- PROC_TYPED_CHILDREN(AssertionIDRequestService,SAMLConstants::SAML20MD_NS,false);
- PROC_TYPED_CHILDREN(NameIDFormat,SAMLConstants::SAML20MD_NS,false);
+ PROC_TYPED_CHILDREN(AuthzService,SAML20MD_NS,false);
+ PROC_TYPED_CHILDREN(AssertionIDRequestService,SAML20MD_NS,false);
+ PROC_TYPED_CHILDREN(NameIDFormat,SAML20MD_NS,false);
RoleDescriptorImpl::processChildElement(childXMLObject,root);
}
};
list<XMLObject*>::iterator m_pos_AssertionIDRequestService;
list<XMLObject*>::iterator m_pos_NameIDFormat;
list<XMLObject*>::iterator m_pos_AttributeProfile;
-
+
void init() {
m_children.push_back(NULL);
m_children.push_back(NULL);
m_pos_AttributeProfile=m_pos_NameIDFormat;
++m_pos_AttributeProfile;
}
-
+
public:
virtual ~AttributeAuthorityDescriptorImpl() {}
-
+
AttributeAuthorityDescriptorImpl(const XMLCh* nsURI, const XMLCh* localName, const XMLCh* prefix, const QName* schemaType)
: AbstractXMLObject(nsURI, localName, prefix, schemaType) {
init();
}
-
+
AttributeAuthorityDescriptorImpl(const AttributeAuthorityDescriptorImpl& src) : AbstractXMLObject(src), RoleDescriptorImpl(src) {
init();
VectorOf(AttributeService) v=getAttributeServices();
RoleDescriptor* cloneRoleDescriptor() const {
return cloneAttributeAuthorityDescriptor();
}
-
+
IMPL_TYPED_CHILDREN(AttributeService,m_pos_AttributeService);
IMPL_TYPED_CHILDREN(AssertionIDRequestService,m_pos_AssertionIDRequestService);
IMPL_TYPED_CHILDREN(NameIDFormat,m_pos_NameIDFormat);
protected:
void processChildElement(XMLObject* childXMLObject, const DOMElement* root) {
- PROC_TYPED_CHILDREN(AttributeService,SAMLConstants::SAML20MD_NS,false);
- PROC_TYPED_CHILDREN(AssertionIDRequestService,SAMLConstants::SAML20MD_NS,false);
- PROC_TYPED_CHILDREN(NameIDFormat,SAMLConstants::SAML20MD_NS,false);
- PROC_TYPED_CHILDREN(AttributeProfile,SAMLConstants::SAML20MD_NS,false);
- PROC_TYPED_FOREIGN_CHILDREN(Attribute,saml2,SAMLConstants::SAML20_NS,false);
+ PROC_TYPED_CHILDREN(AttributeService,SAML20MD_NS,false);
+ PROC_TYPED_CHILDREN(AssertionIDRequestService,SAML20MD_NS,false);
+ PROC_TYPED_CHILDREN(NameIDFormat,SAML20MD_NS,false);
+ PROC_TYPED_CHILDREN(AttributeProfile,SAML20MD_NS,false);
+ PROC_TYPED_FOREIGN_CHILDREN(Attribute,saml2,SAML20_NS,false);
RoleDescriptorImpl::processChildElement(childXMLObject,root);
}
};
class SAML_DLLLOCAL QueryDescriptorTypeImpl : public virtual QueryDescriptorType, public RoleDescriptorImpl
{
void init() {
- m_WantAssertionsSigned=XMLConstants::XML_BOOL_NULL;
+ m_WantAssertionsSigned=XML_BOOL_NULL;
m_children.push_back(NULL);
m_pos_NameIDFormat=m_pos_ContactPerson;
++m_pos_NameIDFormat;
}
-
+
protected:
list<XMLObject*>::iterator m_pos_NameIDFormat;
-
+
QueryDescriptorTypeImpl() {
init();
}
-
+
public:
virtual ~QueryDescriptorTypeImpl() {}
-
+
QueryDescriptorTypeImpl(const XMLCh* nsURI, const XMLCh* localName, const XMLCh* prefix, const QName* schemaType)
: AbstractXMLObject(nsURI, localName, prefix, schemaType) {
init();
}
-
+
QueryDescriptorTypeImpl(const QueryDescriptorTypeImpl& src) : AbstractXMLObject(src), RoleDescriptorImpl(src) {
init();
WantAssertionsSigned(src.m_WantAssertionsSigned);
}
}
}
-
+
IMPL_BOOLEAN_ATTRIB(WantAssertionsSigned);
IMPL_TYPED_CHILDREN(NameIDFormat,m_pos_NameIDFormat);
}
void processChildElement(XMLObject* childXMLObject, const DOMElement* root) {
- PROC_TYPED_CHILDREN(NameIDFormat,SAMLConstants::SAML20MD_NS,false);
+ PROC_TYPED_CHILDREN(NameIDFormat,SAML20MD_NS,false);
RoleDescriptorImpl::processChildElement(childXMLObject,root);
}
};
{
public:
virtual ~AuthnQueryDescriptorTypeImpl() {}
-
+
AuthnQueryDescriptorTypeImpl(const XMLCh* nsURI, const XMLCh* localName, const XMLCh* prefix, const QName* schemaType)
: AbstractXMLObject(nsURI, localName, prefix, schemaType) {}
-
+
AuthnQueryDescriptorTypeImpl(const AuthnQueryDescriptorTypeImpl& src) : AbstractXMLObject(src), QueryDescriptorTypeImpl(src) {}
-
+
IMPL_XMLOBJECT_CLONE(AuthnQueryDescriptorType);
QueryDescriptorType* cloneQueryDescriptorType() const {
return new AuthnQueryDescriptorTypeImpl(*this);
{
public:
virtual ~AttributeQueryDescriptorTypeImpl() {}
-
+
AttributeQueryDescriptorTypeImpl(const XMLCh* nsURI, const XMLCh* localName, const XMLCh* prefix, const QName* schemaType)
: AbstractXMLObject(nsURI, localName, prefix, schemaType) {}
-
+
AttributeQueryDescriptorTypeImpl(const AttributeQueryDescriptorTypeImpl& src)
: AbstractXMLObject(src), QueryDescriptorTypeImpl(src) {
VectorOf(AttributeConsumingService) w=getAttributeConsumingServices();
}
}
}
-
+
IMPL_XMLOBJECT_CLONE(AttributeQueryDescriptorType);
QueryDescriptorType* cloneQueryDescriptorType() const {
return new AttributeQueryDescriptorTypeImpl(*this);
RoleDescriptor* cloneRoleDescriptor() const {
return new AttributeQueryDescriptorTypeImpl(*this);
}
-
+
IMPL_TYPED_CHILDREN(AttributeConsumingService,m_children.end());
protected:
void processChildElement(XMLObject* childXMLObject, const DOMElement* root) {
- PROC_TYPED_CHILDREN(AttributeConsumingService,SAMLConstants::SAML20MD_NS,false);
+ PROC_TYPED_CHILDREN(AttributeConsumingService,SAML20MD_NS,false);
QueryDescriptorTypeImpl::processChildElement(childXMLObject,root);
}
};
{
public:
virtual ~AuthzDecisionQueryDescriptorTypeImpl() {}
-
+
AuthzDecisionQueryDescriptorTypeImpl(const XMLCh* nsURI, const XMLCh* localName, const XMLCh* prefix, const QName* schemaType)
: AbstractXMLObject(nsURI, localName, prefix, schemaType) {}
-
+
AuthzDecisionQueryDescriptorTypeImpl(const AuthzDecisionQueryDescriptorTypeImpl& src)
: AbstractXMLObject(src), QueryDescriptorTypeImpl(src) {
VectorOf(ActionNamespace) w=getActionNamespaces();
}
}
}
-
+
IMPL_XMLOBJECT_CLONE(AuthzDecisionQueryDescriptorType);
QueryDescriptorType* cloneQueryDescriptorType() const {
return new AuthzDecisionQueryDescriptorTypeImpl(*this);
RoleDescriptor* cloneRoleDescriptor() const {
return new AuthzDecisionQueryDescriptorTypeImpl(*this);
}
-
+
IMPL_TYPED_CHILDREN(ActionNamespace,m_children.end());
protected:
void processChildElement(XMLObject* childXMLObject, const DOMElement* root) {
- PROC_TYPED_CHILDREN(ActionNamespace,SAMLConstants::SAML20MD_QUERY_EXT_NS,false);
+ PROC_TYPED_CHILDREN(ActionNamespace,samlconstants::SAML20MD_QUERY_EXT_NS,false);
QueryDescriptorTypeImpl::processChildElement(childXMLObject,root);
}
};
m_pos_AffiliateMember=m_pos_Extensions;
++m_pos_AffiliateMember;
}
-
+
public:
virtual ~AffiliationDescriptorImpl() {
XMLString::release(&m_ID);
delete m_ValidUntil;
delete m_CacheDuration;
}
-
+
AffiliationDescriptorImpl(const XMLCh* nsURI, const XMLCh* localName, const XMLCh* prefix, const QName* schemaType)
: AbstractXMLObject(nsURI, localName, prefix, schemaType) {
init();
}
-
+
AffiliationDescriptorImpl(const AffiliationDescriptorImpl& src)
: AbstractXMLObject(src), AbstractComplexElement(src),
AbstractAttributeExtensibleXMLObject(src), AbstractDOMCachingXMLObject(src) {
setSignature(src.getSignature()->cloneSignature());
if (src.getExtensions())
setExtensions(src.getExtensions()->cloneExtensions());
-
+
VectorOf(KeyDescriptor) v=getKeyDescriptors();
for (vector<KeyDescriptor*>::const_iterator i=src.m_KeyDescriptors.begin(); i!=src.m_KeyDescriptors.end(); i++) {
if (*i) {
Signature* getSignature() const {
return m_Signature;
}
-
+
void setSignature(Signature* sig) {
prepareForAssignment(m_Signature,sig);
*m_pos_Signature=m_Signature=sig;
if (m_Signature)
m_Signature->setContentReference(new opensaml::ContentReference(*this));
}
-
+
IMPL_ID_ATTRIB(ID);
IMPL_STRING_ATTRIB(AffiliationOwnerID);
IMPL_DATETIME_ATTRIB(ValidUntil,SAMLTIME_MAX);
- IMPL_DATETIME_ATTRIB(CacheDuration,0);
+ IMPL_DURATION_ATTRIB(CacheDuration,0);
IMPL_TYPED_CHILD(Extensions);
IMPL_TYPED_CHILDREN(AffiliateMember,m_pos_AffiliateMember);
IMPL_TYPED_CHILDREN(KeyDescriptor,m_children.end());
-
+
void setAttribute(const QName& qualifiedName, const XMLCh* value, bool ID=false) {
if (!qualifiedName.hasNamespaceURI()) {
if (XMLString::equals(qualifiedName.getLocalPart(),ID_ATTRIB_NAME)) {
}
void processChildElement(XMLObject* childXMLObject, const DOMElement* root) {
- PROC_TYPED_FOREIGN_CHILD(Signature,xmlsignature,XMLConstants::XMLSIG_NS,false);
- PROC_TYPED_CHILD(Extensions,SAMLConstants::SAML20MD_NS,false);
- PROC_TYPED_CHILDREN(AffiliateMember,SAMLConstants::SAML20MD_NS,false);
- PROC_TYPED_CHILDREN(KeyDescriptor,SAMLConstants::SAML20MD_NS,false);
+ PROC_TYPED_FOREIGN_CHILD(Signature,xmlsignature,XMLSIG_NS,false);
+ PROC_TYPED_CHILD(Extensions,SAML20MD_NS,false);
+ PROC_TYPED_CHILDREN(AffiliateMember,SAML20MD_NS,false);
+ PROC_TYPED_CHILDREN(KeyDescriptor,SAML20MD_NS,false);
AbstractXMLObjectUnmarshaller::processChildElement(childXMLObject,root);
}
m_pos_ContactPerson=m_pos_Organization;
++m_pos_ContactPerson;
}
-
+
public:
virtual ~EntityDescriptorImpl() {
XMLString::release(&m_ID);
delete m_ValidUntil;
delete m_CacheDuration;
}
-
+
EntityDescriptorImpl(const XMLCh* nsURI, const XMLCh* localName, const XMLCh* prefix, const QName* schemaType)
: AbstractXMLObject(nsURI, localName, prefix, schemaType) {
init();
}
-
+
EntityDescriptorImpl(const EntityDescriptorImpl& src)
: AbstractXMLObject(src), AbstractComplexElement(src),
AbstractAttributeExtensibleXMLObject(src), AbstractDOMCachingXMLObject(src) {
setAffiliationDescriptor(src.getAffiliationDescriptor()->cloneAffiliationDescriptor());
if (src.getOrganization())
setOrganization(src.getOrganization()->cloneOrganization());
-
+
for (list<XMLObject*>::const_iterator i=src.m_children.begin(); i!=src.m_children.end(); i++) {
if (*i) {
IDPSSODescriptor* idp=dynamic_cast<IDPSSODescriptor*>(*i);
getIDPSSODescriptors().push_back(idp->cloneIDPSSODescriptor());
continue;
}
-
+
SPSSODescriptor* sp=dynamic_cast<SPSSODescriptor*>(*i);
if (sp) {
getSPSSODescriptors().push_back(sp->cloneSPSSODescriptor());
getPDPDescriptors().push_back(pdp->clonePDPDescriptor());
continue;
}
-
+
AuthnQueryDescriptorType* authnq=dynamic_cast<AuthnQueryDescriptorType*>(*i);
if (authnq) {
getAuthnQueryDescriptorTypes().push_back(authnq->cloneAuthnQueryDescriptorType());
Signature* getSignature() const {
return m_Signature;
}
-
+
void setSignature(Signature* sig) {
prepareForAssignment(m_Signature,sig);
*m_pos_Signature=m_Signature=sig;
if (m_Signature)
m_Signature->setContentReference(new opensaml::ContentReference(*this));
}
-
+
IMPL_ID_ATTRIB(ID);
IMPL_STRING_ATTRIB(EntityID);
IMPL_DATETIME_ATTRIB(ValidUntil,SAMLTIME_MAX);
- IMPL_DATETIME_ATTRIB(CacheDuration,0);
+ IMPL_DURATION_ATTRIB(CacheDuration,0);
IMPL_TYPED_CHILD(Extensions);
IMPL_TYPED_CHILDREN(RoleDescriptor,m_pos_AffiliationDescriptor);
IMPL_TYPED_CHILDREN(IDPSSODescriptor,m_pos_AffiliationDescriptor);
IMPL_TYPED_CHILD(Organization);
IMPL_TYPED_CHILDREN(ContactPerson,m_pos_ContactPerson);
IMPL_TYPED_CHILDREN(AdditionalMetadataLocation,m_children.end());
-
+
void setAttribute(const QName& qualifiedName, const XMLCh* value, bool ID=false) {
if (!qualifiedName.hasNamespaceURI()) {
if (XMLString::equals(qualifiedName.getLocalPart(),ID_ATTRIB_NAME)) {
AbstractAttributeExtensibleXMLObject::setAttribute(qualifiedName, value, ID);
}
- const IDPSSODescriptor* getIDPSSODescriptor(const XMLCh* protocol) const {
- for (vector<IDPSSODescriptor*>::const_iterator i=m_IDPSSODescriptors.begin(); i!=m_IDPSSODescriptors.end(); i++) {
- if ((*i)->hasSupport(protocol) && (*i)->isValid())
- return (*i);
- }
- return NULL;
- }
-
- const SPSSODescriptor* getSPSSODescriptor(const XMLCh* protocol) const {
- for (vector<SPSSODescriptor*>::const_iterator i=m_SPSSODescriptors.begin(); i!=m_SPSSODescriptors.end(); i++) {
- if ((*i)->hasSupport(protocol) && (*i)->isValid())
- return (*i);
- }
- return NULL;
- }
-
- const AuthnAuthorityDescriptor* getAuthnAuthorityDescriptor(const XMLCh* protocol) const {
- for (vector<AuthnAuthorityDescriptor*>::const_iterator i=m_AuthnAuthorityDescriptors.begin(); i!=m_AuthnAuthorityDescriptors.end(); i++) {
- if ((*i)->hasSupport(protocol) && (*i)->isValid())
- return (*i);
- }
- return NULL;
- }
-
- const AttributeAuthorityDescriptor* getAttributeAuthorityDescriptor(const XMLCh* protocol) const {
- for (vector<AttributeAuthorityDescriptor*>::const_iterator i=m_AttributeAuthorityDescriptors.begin(); i!=m_AttributeAuthorityDescriptors.end(); i++) {
- if ((*i)->hasSupport(protocol) && (*i)->isValid())
- return (*i);
- }
- return NULL;
- }
-
- const PDPDescriptor* getPDPDescriptor(const XMLCh* protocol) const {
- for (vector<PDPDescriptor*>::const_iterator i=m_PDPDescriptors.begin(); i!=m_PDPDescriptors.end(); i++) {
- if ((*i)->hasSupport(protocol) && (*i)->isValid())
- return (*i);
- }
- return NULL;
- }
-
- const AuthnQueryDescriptorType* getAuthnQueryDescriptorType(const XMLCh* protocol) const {
- for (vector<AuthnQueryDescriptorType*>::const_iterator i=m_AuthnQueryDescriptorTypes.begin(); i!=m_AuthnQueryDescriptorTypes.end(); i++) {
- if ((*i)->hasSupport(protocol) && (*i)->isValid())
- return (*i);
- }
- return NULL;
- }
-
- const AttributeQueryDescriptorType* getAttributeQueryDescriptorType(const XMLCh* protocol) const {
- for (vector<AttributeQueryDescriptorType*>::const_iterator i=m_AttributeQueryDescriptorTypes.begin(); i!=m_AttributeQueryDescriptorTypes.end(); i++) {
- if ((*i)->hasSupport(protocol) && (*i)->isValid())
- return (*i);
- }
- return NULL;
- }
-
- const AuthzDecisionQueryDescriptorType* getAuthzDecisionQueryDescriptorType(const XMLCh* protocol) const {
- for (vector<AuthzDecisionQueryDescriptorType*>::const_iterator i=m_AuthzDecisionQueryDescriptorTypes.begin(); i!=m_AuthzDecisionQueryDescriptorTypes.end(); i++) {
- if ((*i)->hasSupport(protocol) && (*i)->isValid())
- return (*i);
- }
- return NULL;
- }
-
const RoleDescriptor* getRoleDescriptor(const xmltooling::QName& qname, const XMLCh* protocol) const {
// Check for "known" elements/types.
- QName q;
- q.setNamespaceURI(SAMLConstants::SAML20MD_NS);
- q.setLocalPart(IDPSSODescriptor::LOCAL_NAME);
- if (q == qname)
- return getIDPSSODescriptor(protocol);
- q.setLocalPart(SPSSODescriptor::LOCAL_NAME);
- if (q == qname)
- return getSPSSODescriptor(protocol);
- q.setLocalPart(AuthnAuthorityDescriptor::LOCAL_NAME);
- if (q == qname)
- return getAuthnAuthorityDescriptor(protocol);
- q.setLocalPart(AttributeAuthorityDescriptor::LOCAL_NAME);
- if (q == qname)
- return getAttributeAuthorityDescriptor(protocol);
- q.setLocalPart(PDPDescriptor::LOCAL_NAME);
- if (q == qname)
- return getPDPDescriptor(protocol);
- q.setNamespaceURI(SAMLConstants::SAML20MD_QUERY_EXT_NS);
- q.setLocalPart(AuthnQueryDescriptorType::TYPE_NAME);
- if (q == qname)
- return getAuthnQueryDescriptorType(protocol);
- q.setLocalPart(AttributeQueryDescriptorType::TYPE_NAME);
- if (q == qname)
- return getAttributeQueryDescriptorType(protocol);
- q.setLocalPart(AuthzDecisionQueryDescriptorType::TYPE_NAME);
- if (q == qname)
- return getAuthzDecisionQueryDescriptorType(protocol);
-
- for (vector<RoleDescriptor*>::const_iterator i=m_RoleDescriptors.begin(); i!=m_RoleDescriptors.end(); i++) {
- if ((*i)->getSchemaType() && qname==(*((*i)->getSchemaType())) && (*i)->hasSupport(protocol) && (*i)->isValid())
- return (*i);
- }
- return NULL;
+ if (qname == IDPSSODescriptor::ELEMENT_QNAME)
+ return find_if(m_IDPSSODescriptors, isValidForProtocol(protocol));
+ if (qname == SPSSODescriptor::ELEMENT_QNAME)
+ return find_if(m_SPSSODescriptors, isValidForProtocol(protocol));
+ if (qname == AuthnAuthorityDescriptor::ELEMENT_QNAME)
+ return find_if(m_AuthnAuthorityDescriptors, isValidForProtocol(protocol));
+ if (qname == AttributeAuthorityDescriptor::ELEMENT_QNAME)
+ return find_if(m_AttributeAuthorityDescriptors, isValidForProtocol(protocol));
+ if (qname == PDPDescriptor::ELEMENT_QNAME)
+ return find_if(m_PDPDescriptors, isValidForProtocol(protocol));
+ if (qname == AuthnQueryDescriptorType::TYPE_QNAME)
+ return find_if(m_AuthnQueryDescriptorTypes, isValidForProtocol(protocol));
+ if (qname == AttributeQueryDescriptorType::TYPE_QNAME)
+ return find_if(m_AttributeQueryDescriptorTypes, isValidForProtocol(protocol));
+ if (qname == AuthzDecisionQueryDescriptorType::TYPE_QNAME)
+ return find_if(m_AuthzDecisionQueryDescriptorTypes, isValidForProtocol(protocol));
+
+ vector<RoleDescriptor*>::const_iterator i =
+ find_if(m_RoleDescriptors.begin(), m_RoleDescriptors.end(), ofTypeValidForProtocol(qname,protocol));
+ return (i!=m_RoleDescriptors.end()) ? *i : NULL;
}
protected:
}
void processChildElement(XMLObject* childXMLObject, const DOMElement* root) {
- PROC_TYPED_FOREIGN_CHILD(Signature,xmlsignature,XMLConstants::XMLSIG_NS,false);
- PROC_TYPED_CHILD(Extensions,SAMLConstants::SAML20MD_NS,false);
- PROC_TYPED_CHILDREN(IDPSSODescriptor,SAMLConstants::SAML20MD_NS,false);
- PROC_TYPED_CHILDREN(SPSSODescriptor,SAMLConstants::SAML20MD_NS,false);
- PROC_TYPED_CHILDREN(AuthnAuthorityDescriptor,SAMLConstants::SAML20MD_NS,false);
- PROC_TYPED_CHILDREN(AttributeAuthorityDescriptor,SAMLConstants::SAML20MD_NS,false);
- PROC_TYPED_CHILDREN(PDPDescriptor,SAMLConstants::SAML20MD_NS,false);
- PROC_TYPED_CHILDREN(AuthnQueryDescriptorType,SAMLConstants::SAML20MD_QUERY_EXT_NS,false);
- PROC_TYPED_CHILDREN(AttributeQueryDescriptorType,SAMLConstants::SAML20MD_QUERY_EXT_NS,false);
- PROC_TYPED_CHILDREN(AuthzDecisionQueryDescriptorType,SAMLConstants::SAML20MD_QUERY_EXT_NS,false);
- PROC_TYPED_CHILDREN(RoleDescriptor,SAMLConstants::SAML20MD_NS,false);
- PROC_TYPED_CHILD(AffiliationDescriptor,SAMLConstants::SAML20MD_NS,false);
- PROC_TYPED_CHILD(Organization,SAMLConstants::SAML20MD_NS,false);
- PROC_TYPED_CHILDREN(ContactPerson,SAMLConstants::SAML20MD_NS,false);
- PROC_TYPED_CHILDREN(AdditionalMetadataLocation,SAMLConstants::SAML20MD_NS,false);
+ PROC_TYPED_FOREIGN_CHILD(Signature,xmlsignature,XMLSIG_NS,false);
+ PROC_TYPED_CHILD(Extensions,SAML20MD_NS,false);
+ PROC_TYPED_CHILDREN(IDPSSODescriptor,SAML20MD_NS,false);
+ PROC_TYPED_CHILDREN(SPSSODescriptor,SAML20MD_NS,false);
+ PROC_TYPED_CHILDREN(AuthnAuthorityDescriptor,SAML20MD_NS,false);
+ PROC_TYPED_CHILDREN(AttributeAuthorityDescriptor,SAML20MD_NS,false);
+ PROC_TYPED_CHILDREN(PDPDescriptor,SAML20MD_NS,false);
+ PROC_TYPED_CHILDREN(AuthnQueryDescriptorType,samlconstants::SAML20MD_QUERY_EXT_NS,false);
+ PROC_TYPED_CHILDREN(AttributeQueryDescriptorType,samlconstants::SAML20MD_QUERY_EXT_NS,false);
+ PROC_TYPED_CHILDREN(AuthzDecisionQueryDescriptorType,samlconstants::SAML20MD_QUERY_EXT_NS,false);
+ PROC_TYPED_CHILDREN(RoleDescriptor,SAML20MD_NS,false);
+ PROC_TYPED_CHILD(AffiliationDescriptor,SAML20MD_NS,false);
+ PROC_TYPED_CHILD(Organization,SAML20MD_NS,false);
+ PROC_TYPED_CHILDREN(ContactPerson,SAML20MD_NS,false);
+ PROC_TYPED_CHILDREN(AdditionalMetadataLocation,SAML20MD_NS,false);
AbstractXMLObjectUnmarshaller::processChildElement(childXMLObject,root);
}
m_pos_Extensions=m_pos_Signature;
++m_pos_Extensions;
}
-
+
public:
virtual ~EntitiesDescriptorImpl() {
XMLString::release(&m_ID);
delete m_ValidUntil;
delete m_CacheDuration;
}
-
+
EntitiesDescriptorImpl(const XMLCh* nsURI, const XMLCh* localName, const XMLCh* prefix, const QName* schemaType)
: AbstractXMLObject(nsURI, localName, prefix, schemaType) {
init();
}
-
+
EntitiesDescriptorImpl(const EntitiesDescriptorImpl& src)
: AbstractXMLObject(src), AbstractComplexElement(src), AbstractDOMCachingXMLObject(src) {
init();
setSignature(src.getSignature()->cloneSignature());
if (src.getExtensions())
setExtensions(src.getExtensions()->cloneExtensions());
-
+
for (list<XMLObject*>::const_iterator i=src.m_children.begin(); i!=src.m_children.end(); i++) {
if (*i) {
EntityDescriptor* e=dynamic_cast<EntityDescriptor*>(*i);
getEntityDescriptors().push_back(e->cloneEntityDescriptor());
continue;
}
-
+
EntitiesDescriptor* es=dynamic_cast<EntitiesDescriptor*>(*i);
if (es) {
getEntitiesDescriptors().push_back(es->cloneEntitiesDescriptor());
Signature* getSignature() const {
return m_Signature;
}
-
+
void setSignature(Signature* sig) {
prepareForAssignment(m_Signature,sig);
*m_pos_Signature=m_Signature=sig;
if (m_Signature)
m_Signature->setContentReference(new opensaml::ContentReference(*this));
}
-
+
IMPL_ID_ATTRIB(ID);
IMPL_STRING_ATTRIB(Name);
IMPL_DATETIME_ATTRIB(ValidUntil,SAMLTIME_MAX);
- IMPL_DATETIME_ATTRIB(CacheDuration,0);
+ IMPL_DURATION_ATTRIB(CacheDuration,0);
IMPL_TYPED_CHILD(Extensions);
IMPL_TYPED_CHILDREN(EntityDescriptor,m_children.end());
IMPL_TYPED_CHILDREN(EntitiesDescriptor,m_children.end());
-
+
protected:
void marshallAttributes(DOMElement* domElement) const {
MARSHALL_ID_ATTRIB(ID,ID,NULL);
}
void processChildElement(XMLObject* childXMLObject, const DOMElement* root) {
- PROC_TYPED_FOREIGN_CHILD(Signature,xmlsignature,XMLConstants::XMLSIG_NS,false);
- PROC_TYPED_CHILD(Extensions,SAMLConstants::SAML20MD_NS,false);
- PROC_TYPED_CHILDREN(EntityDescriptor,SAMLConstants::SAML20MD_NS,false);
- PROC_TYPED_CHILDREN(EntitiesDescriptor,SAMLConstants::SAML20MD_NS,false);
+ PROC_TYPED_FOREIGN_CHILD(Signature,xmlsignature,XMLSIG_NS,false);
+ PROC_TYPED_CHILD(Extensions,SAML20MD_NS,false);
+ PROC_TYPED_CHILDREN(EntityDescriptor,SAML20MD_NS,false);
+ PROC_TYPED_CHILDREN(EntitiesDescriptor,SAML20MD_NS,false);
AbstractXMLObjectUnmarshaller::processChildElement(childXMLObject,root);
}
#pragma warning( pop )
#endif
+IMPL_ELEMENT_QNAME(IDPSSODescriptor, SAML20MD_NS, SAML20MD_PREFIX);
+IMPL_ELEMENT_QNAME(SPSSODescriptor, SAML20MD_NS, SAML20MD_PREFIX);
+IMPL_ELEMENT_QNAME(AuthnAuthorityDescriptor, SAML20MD_NS, SAML20MD_PREFIX);
+IMPL_ELEMENT_QNAME(AttributeAuthorityDescriptor, SAML20MD_NS, SAML20MD_PREFIX);
+IMPL_ELEMENT_QNAME(PDPDescriptor, SAML20MD_NS, SAML20MD_PREFIX);
+IMPL_TYPE_QNAME(AuthnQueryDescriptorType, SAML20MD_QUERY_EXT_NS, SAML20MD_QUERY_EXT_PREFIX);
+IMPL_TYPE_QNAME(AttributeQueryDescriptorType, SAML20MD_QUERY_EXT_NS, SAML20MD_QUERY_EXT_PREFIX);
+IMPL_TYPE_QNAME(AuthzDecisionQueryDescriptorType, SAML20MD_QUERY_EXT_NS, SAML20MD_QUERY_EXT_PREFIX);
+
// Builder Implementations
IMPL_XMLOBJECTBUILDER(AdditionalMetadataLocation);