keycloak-uncached

KEYCLOAK-4346 Validation tests are failing because of ban

2/2/2017 7:21:07 AM

Details

diff --git a/testsuite/integration-arquillian/tests/base/src/test/resources/adapter-test/keycloak-saml/metadata-schema/saml-schema-assertion-2.0.xsd b/testsuite/integration-arquillian/tests/base/src/test/resources/adapter-test/keycloak-saml/metadata-schema/saml-schema-assertion-2.0.xsd
index cdd365d..d4d9a8c 100644
--- a/testsuite/integration-arquillian/tests/base/src/test/resources/adapter-test/keycloak-saml/metadata-schema/saml-schema-assertion-2.0.xsd
+++ b/testsuite/integration-arquillian/tests/base/src/test/resources/adapter-test/keycloak-saml/metadata-schema/saml-schema-assertion-2.0.xsd
@@ -10,9 +10,9 @@
         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"/>
+          schemaLocation="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"/>
+          schemaLocation="xenc-schema.xsd"/>
   <annotation>
     <documentation>
       Document identifier: saml-schema-assertion-2.0
diff --git a/testsuite/integration-arquillian/tests/base/src/test/resources/adapter-test/keycloak-saml/metadata-schema/saml-schema-metadata-2.0.xsd b/testsuite/integration-arquillian/tests/base/src/test/resources/adapter-test/keycloak-saml/metadata-schema/saml-schema-metadata-2.0.xsd
index 5c8d217..35fa2c1 100644
--- a/testsuite/integration-arquillian/tests/base/src/test/resources/adapter-test/keycloak-saml/metadata-schema/saml-schema-metadata-2.0.xsd
+++ b/testsuite/integration-arquillian/tests/base/src/test/resources/adapter-test/keycloak-saml/metadata-schema/saml-schema-metadata-2.0.xsd
@@ -11,13 +11,13 @@
         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"/>
+          schemaLocation="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"/>
+          schemaLocation="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"/>
+          schemaLocation="xml.xsd"/>
   <annotation>
     <documentation>
       Document identifier: saml-schema-metadata-2.0
diff --git a/testsuite/integration-arquillian/tests/base/src/test/resources/adapter-test/keycloak-saml/metadata-schema/xenc-schema.xsd b/testsuite/integration-arquillian/tests/base/src/test/resources/adapter-test/keycloak-saml/metadata-schema/xenc-schema.xsd
new file mode 100644
index 0000000..fb5afc3
--- /dev/null
+++ b/testsuite/integration-arquillian/tests/base/src/test/resources/adapter-test/keycloak-saml/metadata-schema/xenc-schema.xsd
@@ -0,0 +1,136 @@
+<?xml version="1.0" encoding="utf-8"?>
+
+<schema xmlns='http://www.w3.org/2001/XMLSchema' version='1.0'
+        xmlns:xenc='http://www.w3.org/2001/04/xmlenc#'
+        xmlns:ds='http://www.w3.org/2000/09/xmldsig#'
+        targetNamespace='http://www.w3.org/2001/04/xmlenc#'
+        elementFormDefault='qualified'>
+
+    <import namespace='http://www.w3.org/2000/09/xmldsig#'
+            schemaLocation='xmldsig-core-schema.xsd'/>
+
+    <complexType name='EncryptedType' abstract='true'>
+        <sequence>
+            <element name='EncryptionMethod' type='xenc:EncryptionMethodType'
+                     minOccurs='0'/>
+            <element ref='ds:KeyInfo' minOccurs='0'/>
+            <element ref='xenc:CipherData'/>
+            <element ref='xenc:EncryptionProperties' minOccurs='0'/>
+        </sequence>
+        <attribute name='Id' type='ID' use='optional'/>
+        <attribute name='Type' type='anyURI' use='optional'/>
+        <attribute name='MimeType' type='string' use='optional'/>
+        <attribute name='Encoding' type='anyURI' use='optional'/>
+    </complexType>
+
+    <complexType name='EncryptionMethodType' mixed='true'>
+        <sequence>
+            <element name='KeySize' minOccurs='0' type='xenc:KeySizeType'/>
+            <element name='OAEPparams' minOccurs='0' type='base64Binary'/>
+            <any namespace='##other' minOccurs='0' maxOccurs='unbounded'/>
+        </sequence>
+        <attribute name='Algorithm' type='anyURI' use='required'/>
+    </complexType>
+
+    <simpleType name='KeySizeType'>
+        <restriction base="integer"/>
+    </simpleType>
+
+    <element name='CipherData' type='xenc:CipherDataType'/>
+    <complexType name='CipherDataType'>
+        <choice>
+            <element name='CipherValue' type='base64Binary'/>
+            <element ref='xenc:CipherReference'/>
+        </choice>
+    </complexType>
+
+    <element name='CipherReference' type='xenc:CipherReferenceType'/>
+    <complexType name='CipherReferenceType'>
+        <choice>
+            <element name='Transforms' type='xenc:TransformsType' minOccurs='0'/>
+        </choice>
+        <attribute name='URI' type='anyURI' use='required'/>
+    </complexType>
+
+    <complexType name='TransformsType'>
+        <sequence>
+            <element ref='ds:Transform' maxOccurs='unbounded'/>
+        </sequence>
+    </complexType>
+
+
+    <element name='EncryptedData' type='xenc:EncryptedDataType'/>
+    <complexType name='EncryptedDataType'>
+        <complexContent>
+            <extension base='xenc:EncryptedType'>
+            </extension>
+        </complexContent>
+    </complexType>
+
+    <!-- Children of ds:KeyInfo -->
+
+    <element name='EncryptedKey' type='xenc:EncryptedKeyType'/>
+    <complexType name='EncryptedKeyType'>
+        <complexContent>
+            <extension base='xenc:EncryptedType'>
+                <sequence>
+                    <element ref='xenc:ReferenceList' minOccurs='0'/>
+                    <element name='CarriedKeyName' type='string' minOccurs='0'/>
+                </sequence>
+                <attribute name='Recipient' type='string'
+                           use='optional'/>
+            </extension>
+        </complexContent>
+    </complexType>
+
+    <element name="AgreementMethod" type="xenc:AgreementMethodType"/>
+    <complexType name="AgreementMethodType" mixed="true">
+        <sequence>
+            <element name="KA-Nonce" minOccurs="0" type="base64Binary"/>
+            <!-- <element ref="ds:DigestMethod" minOccurs="0"/> -->
+            <any namespace="##other" minOccurs="0" maxOccurs="unbounded"/>
+            <element name="OriginatorKeyInfo" minOccurs="0" type="ds:KeyInfoType"/>
+            <element name="RecipientKeyInfo" minOccurs="0" type="ds:KeyInfoType"/>
+        </sequence>
+        <attribute name="Algorithm" type="anyURI" use="required"/>
+    </complexType>
+
+    <!-- End Children of ds:KeyInfo -->
+
+    <element name='ReferenceList'>
+        <complexType>
+            <choice minOccurs='1' maxOccurs='unbounded'>
+                <element name='DataReference' type='xenc:ReferenceType'/>
+                <element name='KeyReference' type='xenc:ReferenceType'/>
+            </choice>
+        </complexType>
+    </element>
+
+    <complexType name='ReferenceType'>
+        <sequence>
+            <any namespace='##other' minOccurs='0' maxOccurs='unbounded'/>
+        </sequence>
+        <attribute name='URI' type='anyURI' use='required'/>
+    </complexType>
+
+
+    <element name='EncryptionProperties' type='xenc:EncryptionPropertiesType'/>
+    <complexType name='EncryptionPropertiesType'>
+        <sequence>
+            <element ref='xenc:EncryptionProperty' maxOccurs='unbounded'/>
+        </sequence>
+        <attribute name='Id' type='ID' use='optional'/>
+    </complexType>
+
+    <element name='EncryptionProperty' type='xenc:EncryptionPropertyType'/>
+    <complexType name='EncryptionPropertyType' mixed='true'>
+        <choice maxOccurs='unbounded'>
+            <any namespace='##other' processContents='lax'/>
+        </choice>
+        <attribute name='Target' type='anyURI' use='optional'/>
+        <attribute name='Id' type='ID' use='optional'/>
+        <anyAttribute namespace="http://www.w3.org/XML/1998/namespace"/>
+    </complexType>
+
+</schema>
+
diff --git a/testsuite/integration-arquillian/tests/base/src/test/resources/adapter-test/keycloak-saml/metadata-schema/xml.xsd b/testsuite/integration-arquillian/tests/base/src/test/resources/adapter-test/keycloak-saml/metadata-schema/xml.xsd
new file mode 100644
index 0000000..1aa6e17
--- /dev/null
+++ b/testsuite/integration-arquillian/tests/base/src/test/resources/adapter-test/keycloak-saml/metadata-schema/xml.xsd
@@ -0,0 +1,116 @@
+<?xml version='1.0'?>
+<xs:schema targetNamespace="http://www.w3.org/XML/1998/namespace" xmlns:xs="http://www.w3.org/2001/XMLSchema" xml:lang="en">
+
+    <xs:annotation>
+        <xs:documentation>
+            See http://www.w3.org/XML/1998/namespace.html and
+            http://www.w3.org/TR/REC-xml for information about this namespace.
+
+            This schema document describes the XML namespace, in a form
+            suitable for import by other schema documents.
+
+            Note that local names in this namespace are intended to be defined
+            only by the World Wide Web Consortium or its subgroups.  The
+            following names are currently defined in this namespace and should
+            not be used with conflicting semantics by any Working Group,
+            specification, or document instance:
+
+            base (as an attribute name): denotes an attribute whose value
+            provides a URI to be used as the base for interpreting any
+            relative URIs in the scope of the element on which it
+            appears; its value is inherited.  This name is reserved
+            by virtue of its definition in the XML Base specification.
+
+            lang (as an attribute name): denotes an attribute whose value
+            is a language code for the natural language of the content of
+            any element; its value is inherited.  This name is reserved
+            by virtue of its definition in the XML specification.
+
+            space (as an attribute name): denotes an attribute whose
+            value is a keyword indicating what whitespace processing
+            discipline is intended for the content of the element; its
+            value is inherited.  This name is reserved by virtue of its
+            definition in the XML specification.
+
+            Father (in any context at all): denotes Jon Bosak, the chair of
+            the original XML Working Group.  This name is reserved by
+            the following decision of the W3C XML Plenary and
+            XML Coordination groups:
+
+            In appreciation for his vision, leadership and dedication
+            the W3C XML Plenary on this 10th day of February, 2000
+            reserves for Jon Bosak in perpetuity the XML name
+            xml:Father
+        </xs:documentation>
+    </xs:annotation>
+
+    <xs:annotation>
+        <xs:documentation>This schema defines attributes and an attribute group
+            suitable for use by
+            schemas wishing to allow xml:base, xml:lang or xml:space attributes
+            on elements they define.
+
+            To enable this, such a schema must import this schema
+            for the XML namespace, e.g. as follows:
+            &lt;schema . . .>
+            . . .
+            &lt;import namespace="http://www.w3.org/XML/1998/namespace"
+            schemaLocation="http://www.w3.org/2001/03/xml.xsd"/>
+
+            Subsequently, qualified reference to any of the attributes
+            or the group defined below will have the desired effect, e.g.
+
+            &lt;type . . .>
+            . . .
+            &lt;attributeGroup ref="xml:specialAttrs"/>
+
+            will define a type which will schema-validate an instance
+            element with any of those attributes</xs:documentation>
+    </xs:annotation>
+
+    <xs:annotation>
+        <xs:documentation>In keeping with the XML Schema WG's standard versioning
+            policy, this schema document will persist at
+            http://www.w3.org/2001/03/xml.xsd.
+            At the date of issue it can also be found at
+            http://www.w3.org/2001/xml.xsd.
+            The schema document at that URI may however change in the future,
+            in order to remain compatible with the latest version of XML Schema
+            itself.  In other words, if the XML Schema namespace changes, the version
+            of this document at
+            http://www.w3.org/2001/xml.xsd will change
+            accordingly; the version at
+            http://www.w3.org/2001/03/xml.xsd will not change.
+        </xs:documentation>
+    </xs:annotation>
+
+    <xs:attribute name="lang" type="xs:language">
+        <xs:annotation>
+            <xs:documentation>In due course, we should install the relevant ISO 2- and 3-letter
+                codes as the enumerated possible values . . .</xs:documentation>
+        </xs:annotation>
+    </xs:attribute>
+
+    <xs:attribute name="space" default="preserve">
+        <xs:simpleType>
+            <xs:restriction base="xs:NCName">
+                <xs:enumeration value="default"/>
+                <xs:enumeration value="preserve"/>
+            </xs:restriction>
+        </xs:simpleType>
+    </xs:attribute>
+
+    <xs:attribute name="base" type="xs:anyURI">
+        <xs:annotation>
+            <xs:documentation>See http://www.w3.org/TR/xmlbase/ for
+                information about this attribute.</xs:documentation>
+        </xs:annotation>
+    </xs:attribute>
+
+    <xs:attributeGroup name="specialAttrs">
+        <xs:attribute ref="xml:base"/>
+        <xs:attribute ref="xml:lang"/>
+        <xs:attribute ref="xml:space"/>
+    </xs:attributeGroup>
+
+</xs:schema>
diff --git a/testsuite/integration-arquillian/tests/base/src/test/resources/adapter-test/keycloak-saml/metadata-schema/xmldsig-core-schema.xsd b/testsuite/integration-arquillian/tests/base/src/test/resources/adapter-test/keycloak-saml/metadata-schema/xmldsig-core-schema.xsd
new file mode 100644
index 0000000..70d1225
--- /dev/null
+++ b/testsuite/integration-arquillian/tests/base/src/test/resources/adapter-test/keycloak-saml/metadata-schema/xmldsig-core-schema.xsd
@@ -0,0 +1,309 @@
+<?xml version="1.0" encoding="utf-8"?>
+
+<!-- Schema for XML Signatures
+    http://www.w3.org/2000/09/xmldsig#
+    $Revision: 1.1 $ on $Date: 2002/02/08 20:32:26 $ by $Author: reagle $
+
+    Copyright 2001 The Internet Society and W3C (Massachusetts Institute
+    of Technology, Institut National de Recherche en Informatique et en
+    Automatique, Keio University). All Rights Reserved.
+    http://www.w3.org/Consortium/Legal/
+
+    This document is governed by the W3C Software License [1] as described
+    in the FAQ [2].
+
+    [1] http://www.w3.org/Consortium/Legal/copyright-software-19980720
+    [2] http://www.w3.org/Consortium/Legal/IPR-FAQ-20000620.html#DTD
+-->
+
+
+<schema xmlns="http://www.w3.org/2001/XMLSchema"
+        xmlns:ds="http://www.w3.org/2000/09/xmldsig#"
+        targetNamespace="http://www.w3.org/2000/09/xmldsig#"
+        version="0.1" elementFormDefault="qualified">
+
+    <!-- Basic Types Defined for Signatures -->
+
+    <simpleType name="CryptoBinary">
+        <restriction base="base64Binary">
+        </restriction>
+    </simpleType>
+
+    <!-- Start Signature -->
+
+    <element name="Signature" type="ds:SignatureType"/>
+    <complexType name="SignatureType">
+        <sequence>
+            <element ref="ds:SignedInfo"/>
+            <element ref="ds:SignatureValue"/>
+            <element ref="ds:KeyInfo" minOccurs="0"/>
+            <element ref="ds:Object" minOccurs="0" maxOccurs="unbounded"/>
+        </sequence>
+        <attribute name="Id" type="ID" use="optional"/>
+    </complexType>
+
+    <element name="SignatureValue" type="ds:SignatureValueType"/>
+    <complexType name="SignatureValueType">
+        <simpleContent>
+            <extension base="base64Binary">
+                <attribute name="Id" type="ID" use="optional"/>
+            </extension>
+        </simpleContent>
+    </complexType>
+
+    <!-- Start SignedInfo -->
+
+    <element name="SignedInfo" type="ds:SignedInfoType"/>
+    <complexType name="SignedInfoType">
+        <sequence>
+            <element ref="ds:CanonicalizationMethod"/>
+            <element ref="ds:SignatureMethod"/>
+            <element ref="ds:Reference" maxOccurs="unbounded"/>
+        </sequence>
+        <attribute name="Id" type="ID" use="optional"/>
+    </complexType>
+
+    <element name="CanonicalizationMethod" type="ds:CanonicalizationMethodType"/>
+    <complexType name="CanonicalizationMethodType" mixed="true">
+        <sequence>
+            <any namespace="##any" minOccurs="0" maxOccurs="unbounded"/>
+            <!-- (0,unbounded) elements from (1,1) namespace -->
+        </sequence>
+        <attribute name="Algorithm" type="anyURI" use="required"/>
+    </complexType>
+
+    <element name="SignatureMethod" type="ds:SignatureMethodType"/>
+    <complexType name="SignatureMethodType" mixed="true">
+        <sequence>
+            <element name="HMACOutputLength" minOccurs="0" type="ds:HMACOutputLengthType"/>
+            <any namespace="##other" minOccurs="0" maxOccurs="unbounded"/>
+            <!-- (0,unbounded) elements from (1,1) external namespace -->
+        </sequence>
+        <attribute name="Algorithm" type="anyURI" use="required"/>
+    </complexType>
+
+    <!-- Start Reference -->
+
+    <element name="Reference" type="ds:ReferenceType"/>
+    <complexType name="ReferenceType">
+        <sequence>
+            <element ref="ds:Transforms" minOccurs="0"/>
+            <element ref="ds:DigestMethod"/>
+            <element ref="ds:DigestValue"/>
+        </sequence>
+        <attribute name="Id" type="ID" use="optional"/>
+        <attribute name="URI" type="anyURI" use="optional"/>
+        <attribute name="Type" type="anyURI" use="optional"/>
+    </complexType>
+
+    <element name="Transforms" type="ds:TransformsType"/>
+    <complexType name="TransformsType">
+        <sequence>
+            <element ref="ds:Transform" maxOccurs="unbounded"/>
+        </sequence>
+    </complexType>
+
+    <element name="Transform" type="ds:TransformType"/>
+    <complexType name="TransformType" mixed="true">
+        <choice minOccurs="0" maxOccurs="unbounded">
+            <any namespace="##other" processContents="lax"/>
+            <!-- (1,1) elements from (0,unbounded) namespaces -->
+            <element name="XPath" type="string"/>
+        </choice>
+        <attribute name="Algorithm" type="anyURI" use="required"/>
+    </complexType>
+
+    <!-- End Reference -->
+
+    <element name="DigestMethod" type="ds:DigestMethodType"/>
+    <complexType name="DigestMethodType" mixed="true">
+        <sequence>
+            <any namespace="##other" processContents="lax" minOccurs="0" maxOccurs="unbounded"/>
+        </sequence>
+        <attribute name="Algorithm" type="anyURI" use="required"/>
+    </complexType>
+
+    <element name="DigestValue" type="ds:DigestValueType"/>
+    <simpleType name="DigestValueType">
+        <restriction base="base64Binary"/>
+    </simpleType>
+
+    <!-- End SignedInfo -->
+
+    <!-- Start KeyInfo -->
+
+    <element name="KeyInfo" type="ds:KeyInfoType"/>
+    <complexType name="KeyInfoType" mixed="true">
+        <choice maxOccurs="unbounded">
+            <element ref="ds:KeyName"/>
+            <element ref="ds:KeyValue"/>
+            <element ref="ds:RetrievalMethod"/>
+            <element ref="ds:X509Data"/>
+            <element ref="ds:PGPData"/>
+            <element ref="ds:SPKIData"/>
+            <element ref="ds:MgmtData"/>
+            <any processContents="lax" namespace="##other"/>
+            <!-- (1,1) elements from (0,unbounded) namespaces -->
+        </choice>
+        <attribute name="Id" type="ID" use="optional"/>
+    </complexType>
+
+    <element name="KeyName" type="string"/>
+    <element name="MgmtData" type="string"/>
+
+    <element name="KeyValue" type="ds:KeyValueType"/>
+    <complexType name="KeyValueType" mixed="true">
+        <choice>
+            <element ref="ds:DSAKeyValue"/>
+            <element ref="ds:RSAKeyValue"/>
+            <any namespace="##other" processContents="lax"/>
+        </choice>
+    </complexType>
+
+    <element name="RetrievalMethod" type="ds:RetrievalMethodType"/>
+    <complexType name="RetrievalMethodType">
+        <sequence>
+            <element ref="ds:Transforms" minOccurs="0"/>
+        </sequence>
+        <attribute name="URI" type="anyURI"/>
+        <attribute name="Type" type="anyURI" use="optional"/>
+    </complexType>
+
+    <!-- Start X509Data -->
+
+    <element name="X509Data" type="ds:X509DataType"/>
+    <complexType name="X509DataType">
+        <sequence maxOccurs="unbounded">
+            <choice>
+                <element name="X509IssuerSerial" type="ds:X509IssuerSerialType"/>
+                <element name="X509SKI" type="base64Binary"/>
+                <element name="X509SubjectName" type="string"/>
+                <element name="X509Certificate" type="base64Binary"/>
+                <element name="X509CRL" type="base64Binary"/>
+                <any namespace="##other" processContents="lax"/>
+            </choice>
+        </sequence>
+    </complexType>
+
+    <complexType name="X509IssuerSerialType">
+        <sequence>
+            <element name="X509IssuerName" type="string"/>
+            <element name="X509SerialNumber" type="integer"/>
+        </sequence>
+    </complexType>
+
+    <!-- End X509Data -->
+
+    <!-- Begin PGPData -->
+
+    <element name="PGPData" type="ds:PGPDataType"/>
+    <complexType name="PGPDataType">
+        <choice>
+            <sequence>
+                <element name="PGPKeyID" type="base64Binary"/>
+                <element name="PGPKeyPacket" type="base64Binary" minOccurs="0"/>
+                <any namespace="##other" processContents="lax" minOccurs="0"
+                     maxOccurs="unbounded"/>
+            </sequence>
+            <sequence>
+                <element name="PGPKeyPacket" type="base64Binary"/>
+                <any namespace="##other" processContents="lax" minOccurs="0"
+                     maxOccurs="unbounded"/>
+            </sequence>
+        </choice>
+    </complexType>
+
+    <!-- End PGPData -->
+
+    <!-- Begin SPKIData -->
+
+    <element name="SPKIData" type="ds:SPKIDataType"/>
+    <complexType name="SPKIDataType">
+        <sequence maxOccurs="unbounded">
+            <element name="SPKISexp" type="base64Binary"/>
+            <any namespace="##other" processContents="lax" minOccurs="0"/>
+        </sequence>
+    </complexType>
+
+    <!-- End SPKIData -->
+
+    <!-- End KeyInfo -->
+
+    <!-- Start Object (Manifest, SignatureProperty) -->
+
+    <element name="Object" type="ds:ObjectType"/>
+    <complexType name="ObjectType" mixed="true">
+        <sequence minOccurs="0" maxOccurs="unbounded">
+            <any namespace="##any" processContents="lax"/>
+        </sequence>
+        <attribute name="Id" type="ID" use="optional"/>
+        <attribute name="MimeType" type="string" use="optional"/> <!-- add a grep facet -->
+        <attribute name="Encoding" type="anyURI" use="optional"/>
+    </complexType>
+
+    <element name="Manifest" type="ds:ManifestType"/>
+    <complexType name="ManifestType">
+        <sequence>
+            <element ref="ds:Reference" maxOccurs="unbounded"/>
+        </sequence>
+        <attribute name="Id" type="ID" use="optional"/>
+    </complexType>
+
+    <element name="SignatureProperties" type="ds:SignaturePropertiesType"/>
+    <complexType name="SignaturePropertiesType">
+        <sequence>
+            <element ref="ds:SignatureProperty" maxOccurs="unbounded"/>
+        </sequence>
+        <attribute name="Id" type="ID" use="optional"/>
+    </complexType>
+
+    <element name="SignatureProperty" type="ds:SignaturePropertyType"/>
+    <complexType name="SignaturePropertyType" mixed="true">
+        <choice maxOccurs="unbounded">
+            <any namespace="##other" processContents="lax"/>
+            <!-- (1,1) elements from (1,unbounded) namespaces -->
+        </choice>
+        <attribute name="Target" type="anyURI" use="required"/>
+        <attribute name="Id" type="ID" use="optional"/>
+    </complexType>
+
+    <!-- End Object (Manifest, SignatureProperty) -->
+
+    <!-- Start Algorithm Parameters -->
+
+    <simpleType name="HMACOutputLengthType">
+        <restriction base="integer"/>
+    </simpleType>
+
+    <!-- Start KeyValue Element-types -->
+
+    <element name="DSAKeyValue" type="ds:DSAKeyValueType"/>
+    <complexType name="DSAKeyValueType">
+        <sequence>
+            <sequence minOccurs="0">
+                <element name="P" type="ds:CryptoBinary"/>
+                <element name="Q" type="ds:CryptoBinary"/>
+            </sequence>
+            <element name="G" type="ds:CryptoBinary" minOccurs="0"/>
+            <element name="Y" type="ds:CryptoBinary"/>
+            <element name="J" type="ds:CryptoBinary" minOccurs="0"/>
+            <sequence minOccurs="0">
+                <element name="Seed" type="ds:CryptoBinary"/>
+                <element name="PgenCounter" type="ds:CryptoBinary"/>
+            </sequence>
+        </sequence>
+    </complexType>
+
+    <element name="RSAKeyValue" type="ds:RSAKeyValueType"/>
+    <complexType name="RSAKeyValueType">
+        <sequence>
+            <element name="Modulus" type="ds:CryptoBinary"/>
+            <element name="Exponent" type="ds:CryptoBinary"/>
+        </sequence>
+    </complexType>
+
+    <!-- End KeyValue Element-types -->
+
+    <!-- End Signature -->
+
+</schema>