2 * Copyright 2001-2006 Internet2
4 * Licensed under the Apache License, Version 2.0 (the "License");
5 * you may not use this file except in compliance with the License.
6 * You may obtain a copy of the License at
8 * http://www.apache.org/licenses/LICENSE-2.0
10 * Unless required by applicable law or agreed to in writing, software
11 * distributed under the License is distributed on an "AS IS" BASIS,
12 * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
13 * See the License for the specific language governing permissions and
14 * limitations under the License.
18 * @file saml/saml2/metadata/Metadata.h
20 * XMLObjects representing the SAML 2.0 Metadata schema
23 #ifndef __saml2_metadata_h__
24 #define __saml2_metadata_h__
26 #include <saml/saml2/core/Assertions.h>
29 #include <xmltooling/security/KeyInfoSource.h>
31 #define DECL_SAML2MDOBJECTBUILDER(cname) \
32 DECL_XMLOBJECTBUILDER(SAML_API,cname,samlconstants::SAML20MD_NS,samlconstants::SAML20MD_PREFIX)
37 * @namespace opensaml::saml2md
38 * SAML 2.0 metadata namespace
43 * Base class for metadata objects that feature a cacheDuration attribute.
45 class SAML_API CacheableSAMLObject : public virtual xmltooling::XMLObject
48 CacheableSAMLObject() {}
50 ~CacheableSAMLObject() {}
51 DECL_DATETIME_ATTRIB(CacheDuration,CACHEDURATION);
55 * Base class for metadata objects that feature a validUntil attribute.
57 class SAML_API TimeBoundSAMLObject : public virtual xmltooling::XMLObject
60 TimeBoundSAMLObject() {}
62 ~TimeBoundSAMLObject() {}
63 DECL_DATETIME_ATTRIB(ValidUntil,VALIDUNTIL);
64 /** Returns true iff the object is valid at the current time. */
65 bool isValid() const {
66 return time(NULL) <= getValidUntilEpoch();
70 DECL_XMLOBJECT_SIMPLE(SAML_API,AffiliateMember,ID,SAML 2.0 AffiliateMember element);
71 DECL_XMLOBJECT_SIMPLE(SAML_API,AttributeProfile,ProfileURI,SAML 2.0 AttributeProfile element);
72 DECL_XMLOBJECT_SIMPLE(SAML_API,Company,Name,SAML 2.0 Company element);
73 DECL_XMLOBJECT_SIMPLE(SAML_API,EmailAddress,Address,SAML 2.0 EmailAddress element);
74 DECL_XMLOBJECT_SIMPLE(SAML_API,GivenName,Name,SAML 2.0 GivenName element);
75 DECL_XMLOBJECT_SIMPLE(SAML_API,NameIDFormat,Format,SAML 2.0 NameIDFormat element);
76 DECL_XMLOBJECT_SIMPLE(SAML_API,SurName,Name,SAML 2.0 SurName element);
77 DECL_XMLOBJECT_SIMPLE(SAML_API,TelephoneNumber,Number,SAML 2.0 TelephoneNumber element);
79 DECL_XMLOBJECT_SIMPLE(SAML_API,ActionNamespace,Namespace,SAML 2.0 Metadata Extension ActionNamespace element);
80 DECL_XMLOBJECT_SIMPLE(SAML_API,SourceID,ID,SAML 1.x Metadata Profile SourceID element);
82 BEGIN_XMLOBJECT(SAML_API,localizedNameType,xmltooling::XMLObject,SAML 2.0 localizedNameType type);
83 DECL_STRING_ATTRIB(Lang,LANG);
84 /** localizedNameType local name */
85 static const XMLCh TYPE_NAME[];
88 BEGIN_XMLOBJECT(SAML_API,localizedURIType,xmltooling::XMLObject,SAML 2.0 localizedURIType type);
89 DECL_STRING_ATTRIB(Lang,LANG);
90 /** localizedURIType local name */
91 static const XMLCh TYPE_NAME[];
94 BEGIN_XMLOBJECT(SAML_API,OrganizationName,localizedNameType,SAML 2.0 OrganizationName element);
95 DECL_SIMPLE_CONTENT(Name);
98 BEGIN_XMLOBJECT(SAML_API,OrganizationDisplayName,localizedNameType,SAML 2.0 OrganizationDisplayName element);
99 DECL_SIMPLE_CONTENT(Name);
102 BEGIN_XMLOBJECT(SAML_API,OrganizationURL,localizedURIType,SAML 2.0 OrganizationURL element);
103 DECL_SIMPLE_CONTENT(URL);
106 BEGIN_XMLOBJECT(SAML_API,Extensions,xmltooling::ElementExtensibleXMLObject,SAML 2.0 Extensions element);
107 /** ExtensionsType local name */
108 static const XMLCh TYPE_NAME[];
111 BEGIN_XMLOBJECT(SAML_API,Organization,xmltooling::AttributeExtensibleXMLObject,SAML 2.0 Organization element);
112 DECL_TYPED_CHILD(Extensions);
113 DECL_TYPED_CHILDREN(OrganizationName);
114 DECL_TYPED_CHILDREN(OrganizationDisplayName);
115 DECL_TYPED_CHILDREN(OrganizationURL);
116 /** OrganizationType local name */
117 static const XMLCh TYPE_NAME[];
120 BEGIN_XMLOBJECT(SAML_API,ContactPerson,xmltooling::AttributeExtensibleXMLObject,SAML 2.0 ContactPerson element);
121 DECL_STRING_ATTRIB(ContactType,CONTACTTYPE);
122 DECL_TYPED_CHILD(Extensions);
123 DECL_TYPED_CHILD(Company);
124 DECL_TYPED_CHILD(GivenName);
125 DECL_TYPED_CHILD(SurName);
126 DECL_TYPED_CHILDREN(EmailAddress);
127 DECL_TYPED_CHILDREN(TelephoneNumber);
128 /** ContactType local name */
129 static const XMLCh TYPE_NAME[];
130 /** technical Contact Type */
131 static const XMLCh CONTACT_TECHNICAL[];
132 /** support Contact Type */
133 static const XMLCh CONTACT_SUPPORT[];
134 /** administrative Contact Type */
135 static const XMLCh CONTACT_ADMINISTRATIVE[];
136 /** billing Contact Type */
137 static const XMLCh CONTACT_BILLING[];
138 /** other Contact Type */
139 static const XMLCh CONTACT_OTHER[];
142 BEGIN_XMLOBJECT(SAML_API,AdditionalMetadataLocation,xmltooling::XMLObject,SAML 2.0 AdditionalMetadataLocation element);
143 DECL_STRING_ATTRIB(Namespace,NAMESPACE);
144 DECL_SIMPLE_CONTENT(Location);
145 /** AdditionalMetadataLocationType local name */
146 static const XMLCh TYPE_NAME[];
149 BEGIN_XMLOBJECT(SAML_API,KeyDescriptor,xmltooling::XMLObject,SAML 2.0 KeyDescriptor element);
150 DECL_STRING_ATTRIB(Use,USE);
151 DECL_TYPED_FOREIGN_CHILD(KeyInfo,xmlsignature);
152 DECL_TYPED_FOREIGN_CHILDREN(EncryptionMethod,xmlencryption);
153 /** KeyDescriptorType local name */
154 static const XMLCh TYPE_NAME[];
155 /** encryption Key Type */
156 static const XMLCh KEYTYPE_ENCRYPTION[];
157 /** signing Key Type */
158 static const XMLCh KEYTYPE_SIGNING[];
161 BEGIN_XMLOBJECT5(SAML_API,RoleDescriptor,xmltooling::AttributeExtensibleXMLObject,SignableObject,
162 CacheableSAMLObject,TimeBoundSAMLObject,xmltooling::KeyInfoSource,
163 SAML 2.0 RoleDescriptor abstract element);
164 DECL_STRING_ATTRIB(ID,ID);
165 DECL_STRING_ATTRIB(ProtocolSupportEnumeration,PROTOCOLSUPPORTENUMERATION);
166 /** Searches the ProtocolSupportEnumeration attribute for the indicated protocol. */
167 virtual bool hasSupport(const XMLCh* protocol) const=0;
168 DECL_STRING_ATTRIB(ErrorURL,ERRORURL);
169 DECL_INHERITED_TYPED_FOREIGN_CHILD(Signature,xmlsignature);
170 DECL_TYPED_CHILD(Extensions);
171 DECL_TYPED_CHILDREN(KeyDescriptor);
172 DECL_TYPED_CHILD(Organization);
173 DECL_TYPED_CHILDREN(ContactPerson);
176 BEGIN_XMLOBJECT(SAML_API,EndpointType,xmltooling::ElementProxy,SAML 2.0 EndpointType type);
177 DECL_STRING_ATTRIB(Binding,BINDING);
178 DECL_STRING_ATTRIB(Location,LOCATION);
179 DECL_STRING_ATTRIB(ResponseLocation,RESPONSELOCATION);
180 /** EndpointType local name */
181 static const XMLCh TYPE_NAME[];
184 BEGIN_XMLOBJECT(SAML_API,IndexedEndpointType,EndpointType,SAML 2.0 IndexedEndpointType type);
185 DECL_INTEGER_ATTRIB(Index,INDEX);
186 DECL_BOOLEAN_ATTRIB(isDefault,ISDEFAULT,false);
187 /** IndexedEndpointType local name */
188 static const XMLCh TYPE_NAME[];
191 BEGIN_XMLOBJECT(SAML_API,ArtifactResolutionService,IndexedEndpointType,SAML 2.0 ArtifactResolutionService element);
194 BEGIN_XMLOBJECT(SAML_API,SingleLogoutService,EndpointType,SAML 2.0 SingleLogoutService element);
197 BEGIN_XMLOBJECT(SAML_API,ManageNameIDService,EndpointType,SAML 2.0 ManageNameIDService element);
200 BEGIN_XMLOBJECT(SAML_API,SSODescriptorType,RoleDescriptor,SAML 2.0 SSODescriptorType abstract type);
201 DECL_TYPED_CHILDREN(ArtifactResolutionService);
202 DECL_TYPED_CHILDREN(SingleLogoutService);
203 DECL_TYPED_CHILDREN(ManageNameIDService);
204 DECL_TYPED_CHILDREN(NameIDFormat);
205 /** SSODescriptorType local name */
206 static const XMLCh TYPE_NAME[];
209 BEGIN_XMLOBJECT(SAML_API,SingleSignOnService,EndpointType,SAML 2.0 SingleSignOnService element);
212 BEGIN_XMLOBJECT(SAML_API,NameIDMappingService,EndpointType,SAML 2.0 NameIDMappingService element);
215 BEGIN_XMLOBJECT(SAML_API,AssertionIDRequestService,EndpointType,SAML 2.0 AssertionIDRequestService element);
218 BEGIN_XMLOBJECT(SAML_API,IDPSSODescriptor,SSODescriptorType,SAML 2.0 IDPSSODescriptor element);
219 DECL_BOOLEAN_ATTRIB(WantAuthnRequestsSigned,WANTAUTHNREQUESTSSIGNED,false);
220 DECL_TYPED_CHILDREN(SingleSignOnService);
221 DECL_TYPED_CHILDREN(NameIDMappingService);
222 DECL_TYPED_CHILDREN(AssertionIDRequestService);
223 DECL_TYPED_CHILDREN(AttributeProfile);
224 DECL_TYPED_FOREIGN_CHILDREN(Attribute,saml2);
225 /** IDPSSODescriptorType local name */
226 static const XMLCh TYPE_NAME[];
229 BEGIN_XMLOBJECT(SAML_API,ServiceName,localizedNameType,SAML 2.0 ServiceName element);
230 DECL_SIMPLE_CONTENT(Name);
233 BEGIN_XMLOBJECT(SAML_API,ServiceDescription,localizedNameType,SAML 2.0 ServiceDescription element);
234 DECL_SIMPLE_CONTENT(Description);
237 BEGIN_XMLOBJECT(SAML_API,RequestedAttribute,saml2::Attribute,SAML 2.0 RequestedAttribute element);
238 DECL_BOOLEAN_ATTRIB(isRequired,ISREQUIRED,false);
239 /** RequestedAttributeType local name */
240 static const XMLCh TYPE_NAME[];
243 BEGIN_XMLOBJECT(SAML_API,AttributeConsumingService,xmltooling::XMLObject,SAML 2.0 AttributeConsumingService element);
244 DECL_INTEGER_ATTRIB(Index,INDEX);
245 DECL_BOOLEAN_ATTRIB(isDefault,ISDEFAULT,false);
246 DECL_TYPED_CHILDREN(ServiceName);
247 DECL_TYPED_CHILDREN(ServiceDescription);
248 DECL_TYPED_CHILDREN(RequestedAttribute);
249 /** AttributeConsumingServiceType local name */
250 static const XMLCh TYPE_NAME[];
253 BEGIN_XMLOBJECT(SAML_API,AssertionConsumerService,IndexedEndpointType,SAML 2.0 AssertionConsumerService element);
256 BEGIN_XMLOBJECT(SAML_API,SPSSODescriptor,SSODescriptorType,SAML 2.0 SPSSODescriptor element);
257 DECL_BOOLEAN_ATTRIB(AuthnRequestsSigned,AUTHNREQUESTSSIGNED,false);
258 DECL_BOOLEAN_ATTRIB(WantAssertionsSigned,WANTASSERTIONSSIGNED,false);
259 DECL_TYPED_CHILDREN(AssertionConsumerService);
260 DECL_TYPED_CHILDREN(AttributeConsumingService);
261 /** SPSSODescriptorType local name */
262 static const XMLCh TYPE_NAME[];
265 BEGIN_XMLOBJECT(SAML_API,AuthnQueryService,EndpointType,SAML 2.0 AuthnQueryService element);
268 BEGIN_XMLOBJECT(SAML_API,AuthnAuthorityDescriptor,RoleDescriptor,SAML 2.0 AuthnAuthorityDescriptor element);
269 DECL_TYPED_CHILDREN(AuthnQueryService);
270 DECL_TYPED_CHILDREN(AssertionIDRequestService);
271 DECL_TYPED_CHILDREN(NameIDFormat);
272 /** AuthnAuthorityDescriptorType local name */
273 static const XMLCh TYPE_NAME[];
276 BEGIN_XMLOBJECT(SAML_API,AuthzService,EndpointType,SAML 2.0 AuthzService element);
279 BEGIN_XMLOBJECT(SAML_API,PDPDescriptor,RoleDescriptor,SAML 2.0 PDPDescriptor element);
280 DECL_TYPED_CHILDREN(AuthzService);
281 DECL_TYPED_CHILDREN(AssertionIDRequestService);
282 DECL_TYPED_CHILDREN(NameIDFormat);
283 /** PDPDescriptorType local name */
284 static const XMLCh TYPE_NAME[];
287 BEGIN_XMLOBJECT(SAML_API,AttributeService,EndpointType,SAML 2.0 AttributeService element);
290 BEGIN_XMLOBJECT(SAML_API,AttributeAuthorityDescriptor,RoleDescriptor,SAML 2.0 AttributeAuthorityDescriptor element);
291 DECL_TYPED_CHILDREN(AttributeService);
292 DECL_TYPED_CHILDREN(AssertionIDRequestService);
293 DECL_TYPED_CHILDREN(NameIDFormat);
294 DECL_TYPED_CHILDREN(AttributeProfile);
295 DECL_TYPED_FOREIGN_CHILDREN(Attribute,saml2);
296 /** AttributeAuthorityDescriptorType local name */
297 static const XMLCh TYPE_NAME[];
300 BEGIN_XMLOBJECT(SAML_API,QueryDescriptorType,RoleDescriptor,SAML 2.0 QueryDescriptorType abstract type);
301 DECL_BOOLEAN_ATTRIB(WantAssertionsSigned,WANTASSERTIONSSIGNED,false);
302 DECL_TYPED_CHILDREN(NameIDFormat);
303 /** QueryDescriptorType local name */
304 static const XMLCh TYPE_NAME[];
307 BEGIN_XMLOBJECT(SAML_API,AuthnQueryDescriptorType,QueryDescriptorType,SAML 2.0 AuthnQueryDescriptorType extension type);
308 /** AuthnQueryDescriptorType local name */
309 static const XMLCh TYPE_NAME[];
312 BEGIN_XMLOBJECT(SAML_API,AttributeQueryDescriptorType,QueryDescriptorType,SAML 2.0 AttributeQueryDescriptorType extension type);
313 DECL_TYPED_CHILDREN(AttributeConsumingService);
314 /** AttributeQueryDescriptorType local name */
315 static const XMLCh TYPE_NAME[];
318 BEGIN_XMLOBJECT(SAML_API,AuthzDecisionQueryDescriptorType,QueryDescriptorType,SAML 2.0 AuthzDecisionQueryDescriptorType extension type);
319 DECL_TYPED_CHILDREN(ActionNamespace);
320 /** AuthzDecisionQueryDescriptorType local name */
321 static const XMLCh TYPE_NAME[];
324 BEGIN_XMLOBJECT4(SAML_API,AffiliationDescriptor,xmltooling::AttributeExtensibleXMLObject,SignableObject,
325 CacheableSAMLObject,TimeBoundSAMLObject,SAML 2.0 AffiliationDescriptor element);
326 DECL_STRING_ATTRIB(ID,ID);
327 DECL_STRING_ATTRIB(AffiliationOwnerID,AFFILIATIONOWNERID);
328 DECL_INHERITED_TYPED_FOREIGN_CHILD(Signature,xmlsignature);
329 DECL_TYPED_CHILD(Extensions);
330 DECL_TYPED_CHILDREN(AffiliateMember);
331 DECL_TYPED_CHILDREN(KeyDescriptor);
332 /** AffiliationDescriptorType local name */
333 static const XMLCh TYPE_NAME[];
336 BEGIN_XMLOBJECT4(SAML_API,EntityDescriptor,xmltooling::AttributeExtensibleXMLObject,SignableObject,
337 CacheableSAMLObject,TimeBoundSAMLObject,SAML 2.0 EntityDescriptor element);
338 DECL_STRING_ATTRIB(ID,ID);
339 DECL_STRING_ATTRIB(EntityID,ENTITYID);
340 DECL_INHERITED_TYPED_FOREIGN_CHILD(Signature,xmlsignature);
341 DECL_TYPED_CHILD(Extensions);
342 DECL_TYPED_CHILD(AffiliationDescriptor);
343 DECL_TYPED_CHILDREN(RoleDescriptor);
344 DECL_TYPED_CHILDREN(IDPSSODescriptor);
345 DECL_TYPED_CHILDREN(SPSSODescriptor);
346 DECL_TYPED_CHILDREN(AuthnAuthorityDescriptor);
347 DECL_TYPED_CHILDREN(AttributeAuthorityDescriptor);
348 DECL_TYPED_CHILDREN(PDPDescriptor);
349 DECL_TYPED_CHILDREN(AuthnQueryDescriptorType);
350 DECL_TYPED_CHILDREN(AttributeQueryDescriptorType);
351 DECL_TYPED_CHILDREN(AuthzDecisionQueryDescriptorType);
352 /** Finds an IDP role supporting a given protocol. */
353 virtual const IDPSSODescriptor* getIDPSSODescriptor(const XMLCh* protocol) const=0;
354 /** Finds an SP role supporting a given protocol. */
355 virtual const SPSSODescriptor* getSPSSODescriptor(const XMLCh* protocol) const=0;
356 /** Finds an Authn Authority role supporting a given protocol. */
357 virtual const AuthnAuthorityDescriptor* getAuthnAuthorityDescriptor(const XMLCh* protocol) const=0;
358 /** Finds an Attribute Authority role supporting a given protocol. */
359 virtual const AttributeAuthorityDescriptor* getAttributeAuthorityDescriptor(const XMLCh* protocol) const=0;
360 /** Finds a PDP role supporting a given protocol. */
361 virtual const PDPDescriptor* getPDPDescriptor(const XMLCh* protocol) const=0;
362 /** Finds an AuthnQuery role supporting a given protocol. */
363 virtual const AuthnQueryDescriptorType* getAuthnQueryDescriptorType(const XMLCh* protocol) const=0;
364 /** Finds an AttributeQuery role supporting a given protocol. */
365 virtual const AttributeQueryDescriptorType* getAttributeQueryDescriptorType(const XMLCh* protocol) const=0;
366 /** Finds an AuthzDecisionQuery role supporting a given protocol. */
367 virtual const AuthzDecisionQueryDescriptorType* getAuthzDecisionQueryDescriptorType(const XMLCh* protocol) const=0;
368 /** Finds an extension role supporting a given protocol. */
369 virtual const RoleDescriptor* getRoleDescriptor(const xmltooling::QName& qname, const XMLCh* protocol) const=0;
370 /** EntityDescriptorType local name */
371 static const XMLCh TYPE_NAME[];
374 BEGIN_XMLOBJECT3(SAML_API,EntitiesDescriptor,SignableObject,CacheableSAMLObject,
375 TimeBoundSAMLObject,SAML 2.0 EntitiesDescriptor element);
376 DECL_STRING_ATTRIB(ID,ID);
377 DECL_STRING_ATTRIB(Name,NAME);
378 DECL_INHERITED_TYPED_FOREIGN_CHILD(Signature,xmlsignature);
379 DECL_TYPED_CHILD(Extensions);
380 DECL_TYPED_CHILDREN(EntityDescriptor);
381 DECL_TYPED_CHILDREN(EntitiesDescriptor);
382 /** EntitiesDescriptorType local name */
383 static const XMLCh TYPE_NAME[];
386 DECL_SAML2MDOBJECTBUILDER(AdditionalMetadataLocation);
387 DECL_SAML2MDOBJECTBUILDER(AffiliateMember);
388 DECL_SAML2MDOBJECTBUILDER(AffiliationDescriptor);
389 DECL_SAML2MDOBJECTBUILDER(ArtifactResolutionService);
390 DECL_SAML2MDOBJECTBUILDER(AssertionConsumerService);
391 DECL_SAML2MDOBJECTBUILDER(AssertionIDRequestService);
392 DECL_SAML2MDOBJECTBUILDER(AttributeAuthorityDescriptor);
393 DECL_SAML2MDOBJECTBUILDER(AttributeConsumingService);
394 DECL_SAML2MDOBJECTBUILDER(AttributeProfile);
395 DECL_SAML2MDOBJECTBUILDER(AttributeService);
396 DECL_SAML2MDOBJECTBUILDER(AuthnAuthorityDescriptor);
397 DECL_SAML2MDOBJECTBUILDER(AuthnQueryService);
398 DECL_SAML2MDOBJECTBUILDER(AuthzService);
399 DECL_SAML2MDOBJECTBUILDER(Company);
400 DECL_SAML2MDOBJECTBUILDER(ContactPerson);
401 DECL_SAML2MDOBJECTBUILDER(EmailAddress);
402 DECL_SAML2MDOBJECTBUILDER(EntitiesDescriptor);
403 DECL_SAML2MDOBJECTBUILDER(EntityDescriptor);
404 DECL_SAML2MDOBJECTBUILDER(Extensions);
405 DECL_SAML2MDOBJECTBUILDER(GivenName);
406 DECL_SAML2MDOBJECTBUILDER(IDPSSODescriptor);
407 DECL_SAML2MDOBJECTBUILDER(KeyDescriptor);
408 DECL_SAML2MDOBJECTBUILDER(ManageNameIDService);
409 DECL_SAML2MDOBJECTBUILDER(NameIDFormat);
410 DECL_SAML2MDOBJECTBUILDER(NameIDMappingService);
411 DECL_SAML2MDOBJECTBUILDER(Organization);
412 DECL_SAML2MDOBJECTBUILDER(OrganizationName);
413 DECL_SAML2MDOBJECTBUILDER(OrganizationDisplayName);
414 DECL_SAML2MDOBJECTBUILDER(OrganizationURL);
415 DECL_SAML2MDOBJECTBUILDER(PDPDescriptor);
416 DECL_SAML2MDOBJECTBUILDER(RequestedAttribute);
417 DECL_SAML2MDOBJECTBUILDER(ServiceDescription);
418 DECL_SAML2MDOBJECTBUILDER(ServiceName);
419 DECL_SAML2MDOBJECTBUILDER(SingleLogoutService);
420 DECL_SAML2MDOBJECTBUILDER(SingleSignOnService);
421 DECL_SAML2MDOBJECTBUILDER(SPSSODescriptor);
422 DECL_SAML2MDOBJECTBUILDER(SurName);
423 DECL_SAML2MDOBJECTBUILDER(TelephoneNumber);
425 DECL_XMLOBJECTBUILDER(SAML_API,ActionNamespace,samlconstants::SAML20MD_QUERY_EXT_NS,samlconstants::SAML20MD_QUERY_EXT_PREFIX);
426 DECL_XMLOBJECTBUILDER(SAML_API,SourceID,samlconstants::SAML1MD_NS,samlconstants::SAML1MD_PREFIX);
429 * Builder for localizedNameType objects.
431 * This is customized to force the element name to be specified.
433 class SAML_API localizedNameTypeBuilder : public xmltooling::XMLObjectBuilder {
435 virtual ~localizedNameTypeBuilder() {}
436 /** Builder that allows element/type override. */
437 #ifdef HAVE_COVARIANT_RETURNS
438 virtual localizedNameType* buildObject(
440 virtual xmltooling::XMLObject* buildObject(
442 const XMLCh* nsURI, const XMLCh* localName, const XMLCh* prefix=NULL, const xmltooling::QName* schemaType=NULL
445 /** Singleton builder. */
446 static localizedNameType* buildlocalizedNameType(const XMLCh* nsURI, const XMLCh* localName, const XMLCh* prefix=NULL) {
447 const localizedNameTypeBuilder* b = dynamic_cast<const localizedNameTypeBuilder*>(
448 XMLObjectBuilder::getBuilder(xmltooling::QName(samlconstants::SAML20MD_NS,localizedNameType::TYPE_NAME))
451 xmltooling::QName schemaType(samlconstants::SAML20MD_NS,localizedNameType::TYPE_NAME,samlconstants::SAML20MD_PREFIX);
452 #ifdef HAVE_COVARIANT_RETURNS
453 return b->buildObject(nsURI, localName, prefix, &schemaType);
455 return dynamic_cast<localizedNameType*>(b->buildObject(nsURI, localName, prefix, &schemaType));
458 throw xmltooling::XMLObjectException("Unable to obtain typed builder for localizedNameType.");
463 * Builder for localizedURIType objects.
465 * This is customized to force the element name to be specified.
467 class SAML_API localizedURITypeBuilder : public xmltooling::XMLObjectBuilder {
469 virtual ~localizedURITypeBuilder() {}
470 /** Builder that allows element/type override. */
471 #ifdef HAVE_COVARIANT_RETURNS
472 virtual localizedURIType* buildObject(
474 virtual xmltooling::XMLObject* buildObject(
476 const XMLCh* nsURI, const XMLCh* localName, const XMLCh* prefix=NULL, const xmltooling::QName* schemaType=NULL
479 /** Singleton builder. */
480 static localizedURIType* buildlocalizedURIType(const XMLCh* nsURI, const XMLCh* localName, const XMLCh* prefix=NULL) {
481 const localizedURITypeBuilder* b = dynamic_cast<const localizedURITypeBuilder*>(
482 XMLObjectBuilder::getBuilder(xmltooling::QName(samlconstants::SAML20MD_NS,localizedURIType::TYPE_NAME))
485 xmltooling::QName schemaType(samlconstants::SAML20MD_NS,localizedURIType::TYPE_NAME,samlconstants::SAML20MD_PREFIX);
486 #ifdef HAVE_COVARIANT_RETURNS
487 return b->buildObject(nsURI, localName, prefix, &schemaType);
489 return dynamic_cast<localizedURIType*>(b->buildObject(nsURI, localName, prefix, &schemaType));
492 throw xmltooling::XMLObjectException("Unable to obtain typed builder for localizedURIType.");
497 * Builder for EndpointType objects.
499 * This is customized to force the element name to be specified.
501 class SAML_API EndpointTypeBuilder : public xmltooling::XMLObjectBuilder {
503 virtual ~EndpointTypeBuilder() {}
504 /** Builder that allows element/type override. */
505 #ifdef HAVE_COVARIANT_RETURNS
506 virtual EndpointType* buildObject(
508 virtual xmltooling::XMLObject* buildObject(
510 const XMLCh* nsURI, const XMLCh* localName, const XMLCh* prefix=NULL, const xmltooling::QName* schemaType=NULL
513 /** Singleton builder. */
514 static EndpointType* buildEndpointType(const XMLCh* nsURI, const XMLCh* localName, const XMLCh* prefix=NULL) {
515 const EndpointTypeBuilder* b = dynamic_cast<const EndpointTypeBuilder*>(
516 XMLObjectBuilder::getBuilder(xmltooling::QName(samlconstants::SAML20MD_NS,EndpointType::TYPE_NAME))
519 xmltooling::QName schemaType(samlconstants::SAML20MD_NS,EndpointType::TYPE_NAME,samlconstants::SAML20MD_PREFIX);
520 #ifdef HAVE_COVARIANT_RETURNS
521 return b->buildObject(nsURI, localName, prefix, &schemaType);
523 return dynamic_cast<EndpointType*>(b->buildObject(nsURI, localName, prefix, &schemaType));
526 throw xmltooling::XMLObjectException("Unable to obtain typed builder for EndpointType.");
531 * Builder for IndexedEndpointType objects.
533 * This is customized to force the element name to be specified.
535 class SAML_API IndexedEndpointTypeBuilder : public xmltooling::XMLObjectBuilder {
537 virtual ~IndexedEndpointTypeBuilder() {}
538 /** Builder that allows element/type override. */
539 #ifdef HAVE_COVARIANT_RETURNS
540 virtual IndexedEndpointType* buildObject(
542 virtual xmltooling::XMLObject* buildObject(
544 const XMLCh* nsURI, const XMLCh* localName, const XMLCh* prefix=NULL, const xmltooling::QName* schemaType=NULL
547 /** Singleton builder. */
548 static IndexedEndpointType* buildIndexedEndpointType(const XMLCh* nsURI, const XMLCh* localName, const XMLCh* prefix=NULL) {
549 const IndexedEndpointTypeBuilder* b = dynamic_cast<const IndexedEndpointTypeBuilder*>(
550 XMLObjectBuilder::getBuilder(xmltooling::QName(samlconstants::SAML20MD_NS,IndexedEndpointType::TYPE_NAME))
553 xmltooling::QName schemaType(samlconstants::SAML20MD_NS,IndexedEndpointType::TYPE_NAME,samlconstants::SAML20MD_PREFIX);
554 #ifdef HAVE_COVARIANT_RETURNS
555 return b->buildObject(nsURI, localName, prefix, &schemaType);
557 return dynamic_cast<IndexedEndpointType*>(b->buildObject(nsURI, localName, prefix, &schemaType));
560 throw xmltooling::XMLObjectException("Unable to obtain typed builder for IndexedEndpointType.");
565 * Builder for AuthnQueryDescriptorType objects.
567 * This is customized to return a RoleDescriptor element with an
568 * xsi:type of AuthnQueryDescriptorType.
570 class SAML_API AuthnQueryDescriptorTypeBuilder : public xmltooling::XMLObjectBuilder {
572 virtual ~AuthnQueryDescriptorTypeBuilder() {}
573 /** Default builder. */
574 #ifdef HAVE_COVARIANT_RETURNS
575 virtual AuthnQueryDescriptorType* buildObject() const {
577 virtual xmltooling::XMLObject* buildObject() const {
579 xmltooling::QName schemaType(
580 samlconstants::SAML20_NS,AuthnQueryDescriptorType::TYPE_NAME,samlconstants::SAML20MD_QUERY_EXT_PREFIX
583 samlconstants::SAML20_NS,AuthnQueryDescriptorType::LOCAL_NAME,samlconstants::SAML20_PREFIX,&schemaType
586 /** Builder that allows element/type override. */
587 #ifdef HAVE_COVARIANT_RETURNS
588 virtual AuthnQueryDescriptorType* buildObject(
590 virtual xmltooling::XMLObject* buildObject(
592 const XMLCh* nsURI, const XMLCh* localName, const XMLCh* prefix=NULL, const xmltooling::QName* schemaType=NULL
595 /** Singleton builder. */
596 static AuthnQueryDescriptorType* buildAuthnQueryDescriptorType() {
597 const AuthnQueryDescriptorTypeBuilder* b = dynamic_cast<const AuthnQueryDescriptorTypeBuilder*>(
598 XMLObjectBuilder::getBuilder(xmltooling::QName(samlconstants::SAML20MD_QUERY_EXT_NS,AuthnQueryDescriptorType::TYPE_NAME))
601 #ifdef HAVE_COVARIANT_RETURNS
602 return b->buildObject();
604 return dynamic_cast<AuthnQueryDescriptorType*>(b->buildObject());
607 throw xmltooling::XMLObjectException("Unable to obtain typed builder for AuthnQueryDescriptorType.");
612 * Builder for AttributeQueryDescriptorType objects.
614 * This is customized to return a RoleDescriptor element with an
615 * xsi:type of AttributeQueryDescriptorType.
617 class SAML_API AttributeQueryDescriptorTypeBuilder : public xmltooling::XMLObjectBuilder {
619 virtual ~AttributeQueryDescriptorTypeBuilder() {}
620 /** Default builder. */
621 #ifdef HAVE_COVARIANT_RETURNS
622 virtual AttributeQueryDescriptorType* buildObject() const {
624 virtual xmltooling::XMLObject* buildObject() const {
626 xmltooling::QName schemaType(
627 samlconstants::SAML20_NS,AttributeQueryDescriptorType::TYPE_NAME,samlconstants::SAML20MD_QUERY_EXT_PREFIX
630 samlconstants::SAML20_NS,AttributeQueryDescriptorType::LOCAL_NAME,samlconstants::SAML20_PREFIX,&schemaType
633 /** Builder that allows element/type override. */
634 #ifdef HAVE_COVARIANT_RETURNS
635 virtual AttributeQueryDescriptorType* buildObject(
637 virtual xmltooling::XMLObject* buildObject(
639 const XMLCh* nsURI, const XMLCh* localName, const XMLCh* prefix=NULL, const xmltooling::QName* schemaType=NULL
642 /** Singleton builder. */
643 static AttributeQueryDescriptorType* buildAttributeQueryDescriptorType() {
644 const AttributeQueryDescriptorTypeBuilder* b = dynamic_cast<const AttributeQueryDescriptorTypeBuilder*>(
645 XMLObjectBuilder::getBuilder(xmltooling::QName(samlconstants::SAML20MD_QUERY_EXT_NS,AttributeQueryDescriptorType::TYPE_NAME))
648 #ifdef HAVE_COVARIANT_RETURNS
649 return b->buildObject();
651 return dynamic_cast<AttributeQueryDescriptorType*>(b->buildObject());
654 throw xmltooling::XMLObjectException("Unable to obtain typed builder for AttributeQueryDescriptorType.");
659 * Builder for AuthzDecisionQueryDescriptorType objects.
661 * This is customized to return a RoleDescriptor element with an
662 * xsi:type of AuthzDecisionQueryDescriptorType.
664 class SAML_API AuthzDecisionQueryDescriptorTypeBuilder : public xmltooling::XMLObjectBuilder {
666 virtual ~AuthzDecisionQueryDescriptorTypeBuilder() {}
667 /** Default builder. */
668 #ifdef HAVE_COVARIANT_RETURNS
669 virtual AuthzDecisionQueryDescriptorType* buildObject() const {
671 virtual xmltooling::XMLObject* buildObject() const {
673 xmltooling::QName schemaType(
674 samlconstants::SAML20_NS,AuthzDecisionQueryDescriptorType::TYPE_NAME,samlconstants::SAML20MD_QUERY_EXT_PREFIX
677 samlconstants::SAML20_NS,AuthzDecisionQueryDescriptorType::LOCAL_NAME,samlconstants::SAML20_PREFIX,&schemaType
680 /** Builder that allows element/type override. */
681 #ifdef HAVE_COVARIANT_RETURNS
682 virtual AuthzDecisionQueryDescriptorType* buildObject(
684 virtual xmltooling::XMLObject* buildObject(
686 const XMLCh* nsURI, const XMLCh* localName, const XMLCh* prefix=NULL, const xmltooling::QName* schemaType=NULL
689 /** Singleton builder. */
690 static AuthzDecisionQueryDescriptorType* buildAuthzDecisionQueryDescriptorType() {
691 const AuthzDecisionQueryDescriptorTypeBuilder* b = dynamic_cast<const AuthzDecisionQueryDescriptorTypeBuilder*>(
692 XMLObjectBuilder::getBuilder(xmltooling::QName(samlconstants::SAML20MD_QUERY_EXT_NS,AuthzDecisionQueryDescriptorType::TYPE_NAME))
695 #ifdef HAVE_COVARIANT_RETURNS
696 return b->buildObject();
698 return dynamic_cast<AuthzDecisionQueryDescriptorType*>(b->buildObject());
701 throw xmltooling::XMLObjectException("Unable to obtain typed builder for AuthzDecisionQueryDescriptorType.");
706 * Registers builders and validators for SAML 2.0 Metadata classes into the runtime.
708 void SAML_API registerMetadataClasses();
712 #endif /* __saml2_metadata_h__ */