Correct eol-style property.
[shibboleth/cpp-opensaml.git] / schemas / saml-schema-metadata-2.0.xsd
index 0d158c0..923b598 100644 (file)
-<?xml version="1.0" encoding="UTF-8"?>\r
-<schema\r
-    targetNamespace="urn:oasis:names:tc:SAML:2.0:metadata"\r
-    xmlns:md="urn:oasis:names:tc:SAML:2.0:metadata"\r
-    xmlns:ds="http://www.w3.org/2000/09/xmldsig#"\r
-    xmlns:xenc="http://www.w3.org/2001/04/xmlenc#"\r
-    xmlns:saml="urn:oasis:names:tc:SAML:2.0:assertion"\r
-    xmlns="http://www.w3.org/2001/XMLSchema"\r
-    elementFormDefault="unqualified"\r
-    attributeFormDefault="unqualified"\r
-    blockDefault="substitution"\r
-    version="2.0">\r
-    <import namespace="http://www.w3.org/2000/09/xmldsig#"\r
-        schemaLocation="http://www.w3.org/TR/2002/REC-xmldsig-core-20020212/xmldsig-core-schema.xsd"/>\r
-    <import namespace="http://www.w3.org/2001/04/xmlenc#"\r
-        schemaLocation="http://www.w3.org/TR/2002/REC-xmlenc-core-20021210/xenc-schema.xsd"/>\r
-    <import namespace="urn:oasis:names:tc:SAML:2.0:assertion"\r
-        schemaLocation="saml-schema-assertion-2.0.xsd"/>\r
-    <import namespace="http://www.w3.org/XML/1998/namespace"\r
-        schemaLocation="http://www.w3.org/2001/xml.xsd"/>\r
-    <annotation>\r
-        <documentation>\r
-            Document identifier: saml-schema-metadata-2.0\r
-            Location: http://docs.oasis-open.org/security/saml/v2.0/\r
-            Revision history:\r
-              V2.0 (March, 2005):\r
-                Schema for SAML metadata, first published in SAML 2.0.\r
-        </documentation>\r
-    </annotation>\r
-\r
-    <simpleType name="entityIDType">\r
-        <restriction base="anyURI">\r
-            <maxLength value="1024"/>\r
-        </restriction>\r
-    </simpleType>\r
-    <complexType name="localizedNameType">\r
-        <simpleContent>\r
-            <extension base="string">\r
-                <attribute ref="xml:lang" use="required"/>\r
-            </extension>\r
-        </simpleContent>\r
-    </complexType>\r
-    <complexType name="localizedURIType">\r
-        <simpleContent>\r
-            <extension base="anyURI">\r
-                <attribute ref="xml:lang" use="required"/>\r
-            </extension>\r
-        </simpleContent>\r
-    </complexType>\r
-    \r
-    <element name="Extensions" type="md:ExtensionsType"/>\r
-    <complexType final="#all" name="ExtensionsType">\r
-        <sequence>\r
-            <any namespace="##other" processContents="lax" maxOccurs="unbounded"/>\r
-        </sequence>\r
-    </complexType>\r
-    \r
-    <complexType name="EndpointType">\r
-        <sequence>\r
-            <any namespace="##other" processContents="lax" minOccurs="0" maxOccurs="unbounded"/>\r
-        </sequence>\r
-        <attribute name="Binding" type="anyURI" use="required"/>\r
-        <attribute name="Location" type="anyURI" use="required"/>\r
-        <attribute name="ResponseLocation" type="anyURI" use="optional"/>\r
-        <anyAttribute namespace="##other" processContents="lax"/>\r
-    </complexType>\r
-    \r
-    <complexType name="IndexedEndpointType">\r
-        <complexContent>\r
-            <extension base="md:EndpointType">\r
-                <attribute name="index" type="unsignedShort" use="required"/>\r
-                <attribute name="isDefault" type="boolean" use="optional"/>\r
-            </extension>\r
-        </complexContent>\r
-    </complexType>\r
-    \r
-    <element name="EntitiesDescriptor" type="md:EntitiesDescriptorType"/>\r
-    <complexType name="EntitiesDescriptorType">\r
-        <sequence>\r
-            <element ref="ds:Signature" minOccurs="0"/>\r
-            <element ref="md:Extensions" minOccurs="0"/>\r
-            <choice minOccurs="1" maxOccurs="unbounded">\r
-                <element ref="md:EntityDescriptor"/>\r
-                <element ref="md:EntitiesDescriptor"/>\r
-            </choice>\r
-        </sequence>\r
-        <attribute name="validUntil" type="dateTime" use="optional"/>\r
-        <attribute name="cacheDuration" type="duration" use="optional"/>\r
-        <attribute name="ID" type="ID" use="optional"/>\r
-        <attribute name="Name" type="string" use="optional"/>\r
-    </complexType>\r
-\r
-    <element name="EntityDescriptor" type="md:EntityDescriptorType"/>\r
-    <complexType name="EntityDescriptorType">\r
-        <sequence>\r
-            <element ref="ds:Signature" minOccurs="0"/>\r
-            <element ref="md:Extensions" minOccurs="0"/>\r
-            <choice>\r
-                <choice maxOccurs="unbounded">\r
-                    <element ref="md:RoleDescriptor"/>\r
-                    <element ref="md:IDPSSODescriptor"/>\r
-                    <element ref="md:SPSSODescriptor"/>\r
-                    <element ref="md:AuthnAuthorityDescriptor"/>\r
-                    <element ref="md:AttributeAuthorityDescriptor"/>\r
-                    <element ref="md:PDPDescriptor"/>\r
-                </choice>\r
-                <element ref="md:AffiliationDescriptor"/>\r
-            </choice>\r
-            <element ref="md:Organization" minOccurs="0"/>\r
-            <element ref="md:ContactPerson" minOccurs="0" maxOccurs="unbounded"/>\r
-            <element ref="md:AdditionalMetadataLocation" minOccurs="0" maxOccurs="unbounded"/>\r
-        </sequence>\r
-        <attribute name="entityID" type="md:entityIDType" use="required"/>\r
-        <attribute name="validUntil" type="dateTime" use="optional"/>\r
-        <attribute name="cacheDuration" type="duration" use="optional"/>\r
-        <attribute name="ID" type="ID" use="optional"/>\r
-        <anyAttribute namespace="##other" processContents="lax"/>\r
-    </complexType>\r
-    \r
-    <element name="Organization" type="md:OrganizationType"/>\r
-    <complexType name="OrganizationType">\r
-        <sequence>\r
-            <element ref="md:Extensions" minOccurs="0"/>\r
-            <element ref="md:OrganizationName" maxOccurs="unbounded"/>\r
-            <element ref="md:OrganizationDisplayName" maxOccurs="unbounded"/>\r
-            <element ref="md:OrganizationURL" maxOccurs="unbounded"/>\r
-        </sequence>\r
-        <anyAttribute namespace="##other" processContents="lax"/>\r
-    </complexType>\r
-    <element name="OrganizationName" type="md:localizedNameType"/>\r
-    <element name="OrganizationDisplayName" type="md:localizedNameType"/>\r
-    <element name="OrganizationURL" type="md:localizedURIType"/>\r
-    <element name="ContactPerson" type="md:ContactType"/>\r
-    <complexType name="ContactType">\r
-        <sequence>\r
-            <element ref="md:Extensions" minOccurs="0"/>\r
-            <element ref="md:Company" minOccurs="0"/>\r
-            <element ref="md:GivenName" minOccurs="0"/>\r
-            <element ref="md:SurName" minOccurs="0"/>\r
-            <element ref="md:EmailAddress" minOccurs="0" maxOccurs="unbounded"/>\r
-            <element ref="md:TelephoneNumber" minOccurs="0" maxOccurs="unbounded"/>\r
-        </sequence>\r
-        <attribute name="contactType" type="md:ContactTypeType" use="required"/>\r
-        <anyAttribute namespace="##other" processContents="lax"/>\r
-    </complexType>\r
-    <element name="Company" type="string"/>\r
-    <element name="GivenName" type="string"/>\r
-    <element name="SurName" type="string"/>\r
-    <element name="EmailAddress" type="anyURI"/>\r
-    <element name="TelephoneNumber" type="string"/>\r
-    <simpleType name="ContactTypeType">\r
-        <restriction base="string">\r
-            <enumeration value="technical"/>\r
-            <enumeration value="support"/>\r
-            <enumeration value="administrative"/>\r
-            <enumeration value="billing"/>\r
-            <enumeration value="other"/>\r
-        </restriction>\r
-    </simpleType>\r
-\r
-    <element name="AdditionalMetadataLocation" type="md:AdditionalMetadataLocationType"/>\r
-    <complexType name="AdditionalMetadataLocationType">\r
-        <simpleContent>\r
-            <extension base="anyURI">\r
-                <attribute name="namespace" type="anyURI" use="required"/>\r
-            </extension>\r
-        </simpleContent>\r
-    </complexType>\r
-\r
-    <element name="RoleDescriptor" type="md:RoleDescriptorType"/>\r
-    <complexType name="RoleDescriptorType" abstract="true">\r
-        <sequence>\r
-            <element ref="ds:Signature" minOccurs="0"/>\r
-            <element ref="md:Extensions" minOccurs="0"/>\r
-            <element ref="md:KeyDescriptor" minOccurs="0" maxOccurs="unbounded"/>\r
-            <element ref="md:Organization" minOccurs="0"/>\r
-            <element ref="md:ContactPerson" minOccurs="0" maxOccurs="unbounded"/>\r
-        </sequence>\r
-        <attribute name="ID" type="ID" use="optional"/>\r
-        <attribute name="validUntil" type="dateTime" use="optional"/>\r
-        <attribute name="cacheDuration" type="duration" use="optional"/>\r
-        <attribute name="protocolSupportEnumeration" type="md:anyURIListType" use="required"/>\r
-        <attribute name="errorURL" type="anyURI" use="optional"/>\r
-        <anyAttribute namespace="##other" processContents="lax"/>\r
-    </complexType>\r
-    <simpleType name="anyURIListType">\r
-        <list itemType="anyURI"/>\r
-    </simpleType>\r
-\r
-    <element name="KeyDescriptor" type="md:KeyDescriptorType"/>\r
-    <complexType name="KeyDescriptorType">\r
-        <sequence>\r
-            <element ref="ds:KeyInfo"/>\r
-            <element ref="md:EncryptionMethod" minOccurs="0" maxOccurs="unbounded"/>\r
-        </sequence>\r
-        <attribute name="use" type="md:KeyTypes" use="optional"/>\r
-    </complexType>\r
-    <simpleType name="KeyTypes">\r
-        <restriction base="string">\r
-            <enumeration value="encryption"/>\r
-            <enumeration value="signing"/>\r
-        </restriction>\r
-    </simpleType>\r
-    <element name="EncryptionMethod" type="xenc:EncryptionMethodType"/>\r
-    \r
-    <complexType name="SSODescriptorType" abstract="true">\r
-        <complexContent>\r
-            <extension base="md:RoleDescriptorType">\r
-                <sequence>\r
-                    <element ref="md:ArtifactResolutionService" minOccurs="0" maxOccurs="unbounded"/>\r
-                    <element ref="md:SingleLogoutService" minOccurs="0" maxOccurs="unbounded"/>\r
-                    <element ref="md:ManageNameIDService" minOccurs="0" maxOccurs="unbounded"/>\r
-                    <element ref="md:NameIDFormat" minOccurs="0" maxOccurs="unbounded"/>\r
-                </sequence>\r
-            </extension>\r
-        </complexContent>\r
-    </complexType>\r
-    <element name="ArtifactResolutionService" type="md:IndexedEndpointType"/>\r
-    <element name="SingleLogoutService" type="md:EndpointType"/>\r
-    <element name="ManageNameIDService" type="md:EndpointType"/>\r
-    <element name="NameIDFormat" type="anyURI"/>\r
-\r
-    <element name="IDPSSODescriptor" type="md:IDPSSODescriptorType"/>\r
-    <complexType name="IDPSSODescriptorType">\r
-        <complexContent>\r
-            <extension base="md:SSODescriptorType">\r
-                <sequence>\r
-                    <element ref="md:SingleSignOnService" maxOccurs="unbounded"/>\r
-                    <element ref="md:NameIDMappingService" minOccurs="0" maxOccurs="unbounded"/>\r
-                    <element ref="md:AssertionIDRequestService" minOccurs="0" maxOccurs="unbounded"/>\r
-                    <element ref="md:AttributeProfile" minOccurs="0" maxOccurs="unbounded"/>\r
-                    <element ref="saml:Attribute" minOccurs="0" maxOccurs="unbounded"/>\r
-                </sequence>\r
-                <attribute name="WantAuthnRequestsSigned" type="boolean" use="optional"/>\r
-            </extension>\r
-        </complexContent>\r
-    </complexType>\r
-    <element name="SingleSignOnService" type="md:EndpointType"/>\r
-    <element name="NameIDMappingService" type="md:EndpointType"/>\r
-    <element name="AssertionIDRequestService" type="md:EndpointType"/>\r
-    <element name="AttributeProfile" type="anyURI"/>\r
-    \r
-    <element name="SPSSODescriptor" type="md:SPSSODescriptorType"/>\r
-    <complexType name="SPSSODescriptorType">\r
-        <complexContent>\r
-            <extension base="md:SSODescriptorType">\r
-                <sequence>\r
-                    <element ref="md:AssertionConsumerService" maxOccurs="unbounded"/>\r
-                    <element ref="md:AttributeConsumingService" minOccurs="0" maxOccurs="unbounded"/>\r
-                </sequence>\r
-                <attribute name="AuthnRequestsSigned" type="boolean" use="optional"/>\r
-                <attribute name="WantAssertionsSigned" type="boolean" use="optional"/>\r
-            </extension>\r
-        </complexContent>\r
-    </complexType>\r
-    <element name="AssertionConsumerService" type="md:IndexedEndpointType"/>\r
-    <element name="AttributeConsumingService" type="md:AttributeConsumingServiceType"/>\r
-    <complexType name="AttributeConsumingServiceType">\r
-        <sequence>\r
-            <element ref="md:ServiceName" maxOccurs="unbounded"/>\r
-            <element ref="md:ServiceDescription" minOccurs="0" maxOccurs="unbounded"/>\r
-            <element ref="md:RequestedAttribute" maxOccurs="unbounded"/>\r
-        </sequence>\r
-        <attribute name="index" type="unsignedShort" use="required"/>\r
-        <attribute name="isDefault" type="boolean" use="optional"/>\r
-    </complexType>\r
-    <element name="ServiceName" type="md:localizedNameType"/>\r
-    <element name="ServiceDescription" type="md:localizedNameType"/>\r
-    <element name="RequestedAttribute" type="md:RequestedAttributeType"/>\r
-    <complexType name="RequestedAttributeType">\r
-        <complexContent>\r
-            <extension base="saml:AttributeType">\r
-                <attribute name="isRequired" type="boolean" use="optional"/>\r
-            </extension>\r
-        </complexContent>\r
-    </complexType>\r
-  \r
-    <element name="AuthnAuthorityDescriptor" type="md:AuthnAuthorityDescriptorType"/>\r
-    <complexType name="AuthnAuthorityDescriptorType">\r
-        <complexContent>\r
-            <extension base="md:RoleDescriptorType">\r
-                <sequence>\r
-                    <element ref="md:AuthnQueryService" maxOccurs="unbounded"/>\r
-                    <element ref="md:AssertionIDRequestService" minOccurs="0" maxOccurs="unbounded"/>\r
-                    <element ref="md:NameIDFormat" minOccurs="0" maxOccurs="unbounded"/>\r
-                </sequence>\r
-            </extension>\r
-        </complexContent>\r
-    </complexType>\r
-    <element name="AuthnQueryService" type="md:EndpointType"/>\r
-\r
-    <element name="PDPDescriptor" type="md:PDPDescriptorType"/>\r
-    <complexType name="PDPDescriptorType">\r
-        <complexContent>\r
-            <extension base="md:RoleDescriptorType">\r
-                <sequence>\r
-                    <element ref="md:AuthzService" maxOccurs="unbounded"/>\r
-                    <element ref="md:AssertionIDRequestService" minOccurs="0" maxOccurs="unbounded"/>\r
-                    <element ref="md:NameIDFormat" minOccurs="0" maxOccurs="unbounded"/>\r
-                </sequence>\r
-            </extension>\r
-        </complexContent>\r
-    </complexType>\r
-    <element name="AuthzService" type="md:EndpointType"/>\r
-\r
-    <element name="AttributeAuthorityDescriptor" type="md:AttributeAuthorityDescriptorType"/>\r
-    <complexType name="AttributeAuthorityDescriptorType">\r
-        <complexContent>\r
-            <extension base="md:RoleDescriptorType">\r
-                <sequence>\r
-                    <element ref="md:AttributeService" maxOccurs="unbounded"/>\r
-                    <element ref="md:AssertionIDRequestService" minOccurs="0" maxOccurs="unbounded"/>\r
-                    <element ref="md:NameIDFormat" minOccurs="0" maxOccurs="unbounded"/>\r
-                    <element ref="md:AttributeProfile" minOccurs="0" maxOccurs="unbounded"/>\r
-                    <element ref="saml:Attribute" minOccurs="0" maxOccurs="unbounded"/>\r
-                </sequence>\r
-            </extension>\r
-        </complexContent>\r
-    </complexType>\r
-    <element name="AttributeService" type="md:EndpointType"/>\r
-   \r
-    <element name="AffiliationDescriptor" type="md:AffiliationDescriptorType"/>\r
-    <complexType name="AffiliationDescriptorType">\r
-        <sequence>\r
-            <element ref="ds:Signature" minOccurs="0"/>\r
-            <element ref="md:Extensions" minOccurs="0"/>\r
-            <element ref="md:AffiliateMember" maxOccurs="unbounded"/>\r
-            <element ref="md:KeyDescriptor" minOccurs="0" maxOccurs="unbounded"/>\r
-        </sequence>\r
-        <attribute name="affiliationOwnerID" type="md:entityIDType" use="required"/>\r
-        <attribute name="validUntil" type="dateTime" use="optional"/>\r
-        <attribute name="cacheDuration" type="duration" use="optional"/>\r
-        <attribute name="ID" type="ID" use="optional"/>\r
-        <anyAttribute namespace="##other" processContents="lax"/>\r
-    </complexType>\r
-    <element name="AffiliateMember" type="md:entityIDType"/>\r
-</schema>\r
+<?xml version="1.0" encoding="UTF-8"?>
+<schema
+    targetNamespace="urn:oasis:names:tc:SAML:2.0:metadata"
+    xmlns:md="urn:oasis:names:tc:SAML:2.0:metadata"
+    xmlns:ds="http://www.w3.org/2000/09/xmldsig#"
+    xmlns:xenc="http://www.w3.org/2001/04/xmlenc#"
+    xmlns:saml="urn:oasis:names:tc:SAML:2.0:assertion"
+    xmlns="http://www.w3.org/2001/XMLSchema"
+    elementFormDefault="unqualified"
+    attributeFormDefault="unqualified"
+    blockDefault="substitution"
+    version="2.0">
+    <import namespace="http://www.w3.org/2000/09/xmldsig#"
+        schemaLocation="http://www.w3.org/TR/2002/REC-xmldsig-core-20020212/xmldsig-core-schema.xsd"/>
+    <import namespace="http://www.w3.org/2001/04/xmlenc#"
+        schemaLocation="http://www.w3.org/TR/2002/REC-xmlenc-core-20021210/xenc-schema.xsd"/>
+    <import namespace="urn:oasis:names:tc:SAML:2.0:assertion"
+        schemaLocation="saml-schema-assertion-2.0.xsd"/>
+    <import namespace="http://www.w3.org/XML/1998/namespace"
+        schemaLocation="http://www.w3.org/2001/xml.xsd"/>
+    <annotation>
+        <documentation>
+            Document identifier: saml-schema-metadata-2.0
+            Location: http://docs.oasis-open.org/security/saml/v2.0/
+            Revision history:
+              V2.0 (March, 2005):
+                Schema for SAML metadata, first published in SAML 2.0.
+        </documentation>
+    </annotation>
+
+    <simpleType name="entityIDType">
+        <restriction base="anyURI">
+            <maxLength value="1024"/>
+        </restriction>
+    </simpleType>
+    <complexType name="localizedNameType">
+        <simpleContent>
+            <extension base="string">
+                <attribute ref="xml:lang" use="required"/>
+            </extension>
+        </simpleContent>
+    </complexType>
+    <complexType name="localizedURIType">
+        <simpleContent>
+            <extension base="anyURI">
+                <attribute ref="xml:lang" use="required"/>
+            </extension>
+        </simpleContent>
+    </complexType>
+    
+    <element name="Extensions" type="md:ExtensionsType"/>
+    <complexType final="#all" name="ExtensionsType">
+        <sequence>
+            <any namespace="##other" processContents="lax" maxOccurs="unbounded"/>
+        </sequence>
+    </complexType>
+    
+    <complexType name="EndpointType">
+        <sequence>
+            <any namespace="##other" processContents="lax" minOccurs="0" maxOccurs="unbounded"/>
+        </sequence>
+        <attribute name="Binding" type="anyURI" use="required"/>
+        <attribute name="Location" type="anyURI" use="required"/>
+        <attribute name="ResponseLocation" type="anyURI" use="optional"/>
+        <anyAttribute namespace="##other" processContents="lax"/>
+    </complexType>
+    
+    <complexType name="IndexedEndpointType">
+        <complexContent>
+            <extension base="md:EndpointType">
+                <attribute name="index" type="unsignedShort" use="required"/>
+                <attribute name="isDefault" type="boolean" use="optional"/>
+            </extension>
+        </complexContent>
+    </complexType>
+    
+    <element name="EntitiesDescriptor" type="md:EntitiesDescriptorType"/>
+    <complexType name="EntitiesDescriptorType">
+        <sequence>
+            <element ref="ds:Signature" minOccurs="0"/>
+            <element ref="md:Extensions" minOccurs="0"/>
+            <choice minOccurs="1" maxOccurs="unbounded">
+                <element ref="md:EntityDescriptor"/>
+                <element ref="md:EntitiesDescriptor"/>
+            </choice>
+        </sequence>
+        <attribute name="validUntil" type="dateTime" use="optional"/>
+        <attribute name="cacheDuration" type="duration" use="optional"/>
+        <attribute name="ID" type="ID" use="optional"/>
+        <attribute name="Name" type="string" use="optional"/>
+    </complexType>
+
+    <element name="EntityDescriptor" type="md:EntityDescriptorType"/>
+    <complexType name="EntityDescriptorType">
+        <sequence>
+            <element ref="ds:Signature" minOccurs="0"/>
+            <element ref="md:Extensions" minOccurs="0"/>
+            <choice>
+                <choice maxOccurs="unbounded">
+                    <element ref="md:RoleDescriptor"/>
+                    <element ref="md:IDPSSODescriptor"/>
+                    <element ref="md:SPSSODescriptor"/>
+                    <element ref="md:AuthnAuthorityDescriptor"/>
+                    <element ref="md:AttributeAuthorityDescriptor"/>
+                    <element ref="md:PDPDescriptor"/>
+                </choice>
+                <element ref="md:AffiliationDescriptor"/>
+            </choice>
+            <element ref="md:Organization" minOccurs="0"/>
+            <element ref="md:ContactPerson" minOccurs="0" maxOccurs="unbounded"/>
+            <element ref="md:AdditionalMetadataLocation" minOccurs="0" maxOccurs="unbounded"/>
+        </sequence>
+        <attribute name="entityID" type="md:entityIDType" use="required"/>
+        <attribute name="validUntil" type="dateTime" use="optional"/>
+        <attribute name="cacheDuration" type="duration" use="optional"/>
+        <attribute name="ID" type="ID" use="optional"/>
+        <anyAttribute namespace="##other" processContents="lax"/>
+    </complexType>
+    
+    <element name="Organization" type="md:OrganizationType"/>
+    <complexType name="OrganizationType">
+        <sequence>
+            <element ref="md:Extensions" minOccurs="0"/>
+            <element ref="md:OrganizationName" maxOccurs="unbounded"/>
+            <element ref="md:OrganizationDisplayName" maxOccurs="unbounded"/>
+            <element ref="md:OrganizationURL" maxOccurs="unbounded"/>
+        </sequence>
+        <anyAttribute namespace="##other" processContents="lax"/>
+    </complexType>
+    <element name="OrganizationName" type="md:localizedNameType"/>
+    <element name="OrganizationDisplayName" type="md:localizedNameType"/>
+    <element name="OrganizationURL" type="md:localizedURIType"/>
+    <element name="ContactPerson" type="md:ContactType"/>
+    <complexType name="ContactType">
+        <sequence>
+            <element ref="md:Extensions" minOccurs="0"/>
+            <element ref="md:Company" minOccurs="0"/>
+            <element ref="md:GivenName" minOccurs="0"/>
+            <element ref="md:SurName" minOccurs="0"/>
+            <element ref="md:EmailAddress" minOccurs="0" maxOccurs="unbounded"/>
+            <element ref="md:TelephoneNumber" minOccurs="0" maxOccurs="unbounded"/>
+        </sequence>
+        <attribute name="contactType" type="md:ContactTypeType" use="required"/>
+        <anyAttribute namespace="##other" processContents="lax"/>
+    </complexType>
+    <element name="Company" type="string"/>
+    <element name="GivenName" type="string"/>
+    <element name="SurName" type="string"/>
+    <element name="EmailAddress" type="anyURI"/>
+    <element name="TelephoneNumber" type="string"/>
+    <simpleType name="ContactTypeType">
+        <restriction base="string">
+            <enumeration value="technical"/>
+            <enumeration value="support"/>
+            <enumeration value="administrative"/>
+            <enumeration value="billing"/>
+            <enumeration value="other"/>
+        </restriction>
+    </simpleType>
+
+    <element name="AdditionalMetadataLocation" type="md:AdditionalMetadataLocationType"/>
+    <complexType name="AdditionalMetadataLocationType">
+        <simpleContent>
+            <extension base="anyURI">
+                <attribute name="namespace" type="anyURI" use="required"/>
+            </extension>
+        </simpleContent>
+    </complexType>
+
+    <element name="RoleDescriptor" type="md:RoleDescriptorType"/>
+    <complexType name="RoleDescriptorType" abstract="true">
+        <sequence>
+            <element ref="ds:Signature" minOccurs="0"/>
+            <element ref="md:Extensions" minOccurs="0"/>
+            <element ref="md:KeyDescriptor" minOccurs="0" maxOccurs="unbounded"/>
+            <element ref="md:Organization" minOccurs="0"/>
+            <element ref="md:ContactPerson" minOccurs="0" maxOccurs="unbounded"/>
+        </sequence>
+        <attribute name="ID" type="ID" use="optional"/>
+        <attribute name="validUntil" type="dateTime" use="optional"/>
+        <attribute name="cacheDuration" type="duration" use="optional"/>
+        <attribute name="protocolSupportEnumeration" type="md:anyURIListType" use="required"/>
+        <attribute name="errorURL" type="anyURI" use="optional"/>
+        <anyAttribute namespace="##other" processContents="lax"/>
+    </complexType>
+    <simpleType name="anyURIListType">
+        <list itemType="anyURI"/>
+    </simpleType>
+
+    <element name="KeyDescriptor" type="md:KeyDescriptorType"/>
+    <complexType name="KeyDescriptorType">
+        <sequence>
+            <element ref="ds:KeyInfo"/>
+            <element ref="md:EncryptionMethod" minOccurs="0" maxOccurs="unbounded"/>
+        </sequence>
+        <attribute name="use" type="md:KeyTypes" use="optional"/>
+    </complexType>
+    <simpleType name="KeyTypes">
+        <restriction base="string">
+            <enumeration value="encryption"/>
+            <enumeration value="signing"/>
+        </restriction>
+    </simpleType>
+    <element name="EncryptionMethod" type="xenc:EncryptionMethodType"/>
+    
+    <complexType name="SSODescriptorType" abstract="true">
+        <complexContent>
+            <extension base="md:RoleDescriptorType">
+                <sequence>
+                    <element ref="md:ArtifactResolutionService" minOccurs="0" maxOccurs="unbounded"/>
+                    <element ref="md:SingleLogoutService" minOccurs="0" maxOccurs="unbounded"/>
+                    <element ref="md:ManageNameIDService" minOccurs="0" maxOccurs="unbounded"/>
+                    <element ref="md:NameIDFormat" minOccurs="0" maxOccurs="unbounded"/>
+                </sequence>
+            </extension>
+        </complexContent>
+    </complexType>
+    <element name="ArtifactResolutionService" type="md:IndexedEndpointType"/>
+    <element name="SingleLogoutService" type="md:EndpointType"/>
+    <element name="ManageNameIDService" type="md:EndpointType"/>
+    <element name="NameIDFormat" type="anyURI"/>
+
+    <element name="IDPSSODescriptor" type="md:IDPSSODescriptorType"/>
+    <complexType name="IDPSSODescriptorType">
+        <complexContent>
+            <extension base="md:SSODescriptorType">
+                <sequence>
+                    <element ref="md:SingleSignOnService" maxOccurs="unbounded"/>
+                    <element ref="md:NameIDMappingService" minOccurs="0" maxOccurs="unbounded"/>
+                    <element ref="md:AssertionIDRequestService" minOccurs="0" maxOccurs="unbounded"/>
+                    <element ref="md:AttributeProfile" minOccurs="0" maxOccurs="unbounded"/>
+                    <element ref="saml:Attribute" minOccurs="0" maxOccurs="unbounded"/>
+                </sequence>
+                <attribute name="WantAuthnRequestsSigned" type="boolean" use="optional"/>
+            </extension>
+        </complexContent>
+    </complexType>
+    <element name="SingleSignOnService" type="md:EndpointType"/>
+    <element name="NameIDMappingService" type="md:EndpointType"/>
+    <element name="AssertionIDRequestService" type="md:EndpointType"/>
+    <element name="AttributeProfile" type="anyURI"/>
+    
+    <element name="SPSSODescriptor" type="md:SPSSODescriptorType"/>
+    <complexType name="SPSSODescriptorType">
+        <complexContent>
+            <extension base="md:SSODescriptorType">
+                <sequence>
+                    <element ref="md:AssertionConsumerService" maxOccurs="unbounded"/>
+                    <element ref="md:AttributeConsumingService" minOccurs="0" maxOccurs="unbounded"/>
+                </sequence>
+                <attribute name="AuthnRequestsSigned" type="boolean" use="optional"/>
+                <attribute name="WantAssertionsSigned" type="boolean" use="optional"/>
+            </extension>
+        </complexContent>
+    </complexType>
+    <element name="AssertionConsumerService" type="md:IndexedEndpointType"/>
+    <element name="AttributeConsumingService" type="md:AttributeConsumingServiceType"/>
+    <complexType name="AttributeConsumingServiceType">
+        <sequence>
+            <element ref="md:ServiceName" maxOccurs="unbounded"/>
+            <element ref="md:ServiceDescription" minOccurs="0" maxOccurs="unbounded"/>
+            <element ref="md:RequestedAttribute" maxOccurs="unbounded"/>
+        </sequence>
+        <attribute name="index" type="unsignedShort" use="required"/>
+        <attribute name="isDefault" type="boolean" use="optional"/>
+    </complexType>
+    <element name="ServiceName" type="md:localizedNameType"/>
+    <element name="ServiceDescription" type="md:localizedNameType"/>
+    <element name="RequestedAttribute" type="md:RequestedAttributeType"/>
+    <complexType name="RequestedAttributeType">
+        <complexContent>
+            <extension base="saml:AttributeType">
+                <attribute name="isRequired" type="boolean" use="optional"/>
+            </extension>
+        </complexContent>
+    </complexType>
+  
+    <element name="AuthnAuthorityDescriptor" type="md:AuthnAuthorityDescriptorType"/>
+    <complexType name="AuthnAuthorityDescriptorType">
+        <complexContent>
+            <extension base="md:RoleDescriptorType">
+                <sequence>
+                    <element ref="md:AuthnQueryService" maxOccurs="unbounded"/>
+                    <element ref="md:AssertionIDRequestService" minOccurs="0" maxOccurs="unbounded"/>
+                    <element ref="md:NameIDFormat" minOccurs="0" maxOccurs="unbounded"/>
+                </sequence>
+            </extension>
+        </complexContent>
+    </complexType>
+    <element name="AuthnQueryService" type="md:EndpointType"/>
+
+    <element name="PDPDescriptor" type="md:PDPDescriptorType"/>
+    <complexType name="PDPDescriptorType">
+        <complexContent>
+            <extension base="md:RoleDescriptorType">
+                <sequence>
+                    <element ref="md:AuthzService" maxOccurs="unbounded"/>
+                    <element ref="md:AssertionIDRequestService" minOccurs="0" maxOccurs="unbounded"/>
+                    <element ref="md:NameIDFormat" minOccurs="0" maxOccurs="unbounded"/>
+                </sequence>
+            </extension>
+        </complexContent>
+    </complexType>
+    <element name="AuthzService" type="md:EndpointType"/>
+
+    <element name="AttributeAuthorityDescriptor" type="md:AttributeAuthorityDescriptorType"/>
+    <complexType name="AttributeAuthorityDescriptorType">
+        <complexContent>
+            <extension base="md:RoleDescriptorType">
+                <sequence>
+                    <element ref="md:AttributeService" maxOccurs="unbounded"/>
+                    <element ref="md:AssertionIDRequestService" minOccurs="0" maxOccurs="unbounded"/>
+                    <element ref="md:NameIDFormat" minOccurs="0" maxOccurs="unbounded"/>
+                    <element ref="md:AttributeProfile" minOccurs="0" maxOccurs="unbounded"/>
+                    <element ref="saml:Attribute" minOccurs="0" maxOccurs="unbounded"/>
+                </sequence>
+            </extension>
+        </complexContent>
+    </complexType>
+    <element name="AttributeService" type="md:EndpointType"/>
+   
+    <element name="AffiliationDescriptor" type="md:AffiliationDescriptorType"/>
+    <complexType name="AffiliationDescriptorType">
+        <sequence>
+            <element ref="ds:Signature" minOccurs="0"/>
+            <element ref="md:Extensions" minOccurs="0"/>
+            <element ref="md:AffiliateMember" maxOccurs="unbounded"/>
+            <element ref="md:KeyDescriptor" minOccurs="0" maxOccurs="unbounded"/>
+        </sequence>
+        <attribute name="affiliationOwnerID" type="md:entityIDType" use="required"/>
+        <attribute name="validUntil" type="dateTime" use="optional"/>
+        <attribute name="cacheDuration" type="duration" use="optional"/>
+        <attribute name="ID" type="ID" use="optional"/>
+        <anyAttribute namespace="##other" processContents="lax"/>
+    </complexType>
+    <element name="AffiliateMember" type="md:entityIDType"/>
+</schema>