main
1<?xml version="1.0" encoding="utf-8"?>
2
3<!-- Schema for XML Signatures
4 http://www.w3.org/2000/09/xmldsig#
5 $Revision: 1.1 $ on $Date: 2002/02/08 20:32:26 $ by $Author: reagle $
6
7 Copyright 2001 The Internet Society and W3C (Massachusetts Institute
8 of Technology, Institut National de Recherche en Informatique et en
9 Automatique, Keio University). All Rights Reserved.
10 http://www.w3.org/Consortium/Legal/
11
12 This document is governed by the W3C Software License [1] as described
13 in the FAQ [2].
14
15 [1] http://www.w3.org/Consortium/Legal/copyright-software-19980720
16 [2] http://www.w3.org/Consortium/Legal/IPR-FAQ-20000620.html#DTD
17-->
18
19
20<schema xmlns="http://www.w3.org/2001/XMLSchema"
21 xmlns:ds="http://www.w3.org/2000/09/xmldsig#"
22 targetNamespace="http://www.w3.org/2000/09/xmldsig#"
23 version="0.1" elementFormDefault="qualified">
24
25<!-- Basic Types Defined for Signatures -->
26
27<simpleType name="CryptoBinary">
28 <restriction base="base64Binary">
29 </restriction>
30</simpleType>
31
32<!-- Start Signature -->
33
34<element name="Signature" type="ds:SignatureType"/>
35<complexType name="SignatureType">
36 <sequence>
37 <element ref="ds:SignedInfo"/>
38 <element ref="ds:SignatureValue"/>
39 <element ref="ds:KeyInfo" minOccurs="0"/>
40 <element ref="ds:Object" minOccurs="0" maxOccurs="unbounded"/>
41 </sequence>
42 <attribute name="Id" type="ID" use="optional"/>
43</complexType>
44
45 <element name="SignatureValue" type="ds:SignatureValueType"/>
46 <complexType name="SignatureValueType">
47 <simpleContent>
48 <extension base="base64Binary">
49 <attribute name="Id" type="ID" use="optional"/>
50 </extension>
51 </simpleContent>
52 </complexType>
53
54<!-- Start SignedInfo -->
55
56<element name="SignedInfo" type="ds:SignedInfoType"/>
57<complexType name="SignedInfoType">
58 <sequence>
59 <element ref="ds:CanonicalizationMethod"/>
60 <element ref="ds:SignatureMethod"/>
61 <element ref="ds:Reference" maxOccurs="unbounded"/>
62 </sequence>
63 <attribute name="Id" type="ID" use="optional"/>
64</complexType>
65
66 <element name="CanonicalizationMethod" type="ds:CanonicalizationMethodType"/>
67 <complexType name="CanonicalizationMethodType" mixed="true">
68 <sequence>
69 <any namespace="##any" minOccurs="0" maxOccurs="unbounded"/>
70 <!-- (0,unbounded) elements from (1,1) namespace -->
71 </sequence>
72 <attribute name="Algorithm" type="anyURI" use="required"/>
73 </complexType>
74
75 <element name="SignatureMethod" type="ds:SignatureMethodType"/>
76 <complexType name="SignatureMethodType" mixed="true">
77 <sequence>
78 <element name="HMACOutputLength" minOccurs="0" type="ds:HMACOutputLengthType"/>
79 <any namespace="##other" minOccurs="0" maxOccurs="unbounded"/>
80 <!-- (0,unbounded) elements from (1,1) external namespace -->
81 </sequence>
82 <attribute name="Algorithm" type="anyURI" use="required"/>
83 </complexType>
84
85<!-- Start Reference -->
86
87<element name="Reference" type="ds:ReferenceType"/>
88<complexType name="ReferenceType">
89 <sequence>
90 <element ref="ds:Transforms" minOccurs="0"/>
91 <element ref="ds:DigestMethod"/>
92 <element ref="ds:DigestValue"/>
93 </sequence>
94 <attribute name="Id" type="ID" use="optional"/>
95 <attribute name="URI" type="anyURI" use="optional"/>
96 <attribute name="Type" type="anyURI" use="optional"/>
97</complexType>
98
99 <element name="Transforms" type="ds:TransformsType"/>
100 <complexType name="TransformsType">
101 <sequence>
102 <element ref="ds:Transform" maxOccurs="unbounded"/>
103 </sequence>
104 </complexType>
105
106 <element name="Transform" type="ds:TransformType"/>
107 <complexType name="TransformType" mixed="true">
108 <choice minOccurs="0" maxOccurs="unbounded">
109 <any namespace="##other" processContents="lax"/>
110 <!-- (1,1) elements from (0,unbounded) namespaces -->
111 <element name="XPath" type="string"/>
112 </choice>
113 <attribute name="Algorithm" type="anyURI" use="required"/>
114 </complexType>
115
116<!-- End Reference -->
117
118<element name="DigestMethod" type="ds:DigestMethodType"/>
119<complexType name="DigestMethodType" mixed="true">
120 <sequence>
121 <any namespace="##other" processContents="lax" minOccurs="0" maxOccurs="unbounded"/>
122 </sequence>
123 <attribute name="Algorithm" type="anyURI" use="required"/>
124</complexType>
125
126<element name="DigestValue" type="ds:DigestValueType"/>
127<simpleType name="DigestValueType">
128 <restriction base="base64Binary"/>
129</simpleType>
130
131<!-- End SignedInfo -->
132
133<!-- Start KeyInfo -->
134
135<element name="KeyInfo" type="ds:KeyInfoType"/>
136<complexType name="KeyInfoType" mixed="true">
137 <choice maxOccurs="unbounded">
138 <element ref="ds:KeyName"/>
139 <element ref="ds:KeyValue"/>
140 <element ref="ds:RetrievalMethod"/>
141 <element ref="ds:X509Data"/>
142 <element ref="ds:PGPData"/>
143 <element ref="ds:SPKIData"/>
144 <element ref="ds:MgmtData"/>
145 <any processContents="lax" namespace="##other"/>
146 <!-- (1,1) elements from (0,unbounded) namespaces -->
147 </choice>
148 <attribute name="Id" type="ID" use="optional"/>
149</complexType>
150
151 <element name="KeyName" type="string"/>
152 <element name="MgmtData" type="string"/>
153
154 <element name="KeyValue" type="ds:KeyValueType"/>
155 <complexType name="KeyValueType" mixed="true">
156 <choice>
157 <element ref="ds:DSAKeyValue"/>
158 <element ref="ds:RSAKeyValue"/>
159 <any namespace="##other" processContents="lax"/>
160 </choice>
161 </complexType>
162
163 <element name="RetrievalMethod" type="ds:RetrievalMethodType"/>
164 <complexType name="RetrievalMethodType">
165 <sequence>
166 <element ref="ds:Transforms" minOccurs="0"/>
167 </sequence>
168 <attribute name="URI" type="anyURI"/>
169 <attribute name="Type" type="anyURI" use="optional"/>
170 </complexType>
171
172<!-- Start X509Data -->
173
174<element name="X509Data" type="ds:X509DataType"/>
175<complexType name="X509DataType">
176 <sequence maxOccurs="unbounded">
177 <choice>
178 <element name="X509IssuerSerial" type="ds:X509IssuerSerialType"/>
179 <element name="X509SKI" type="base64Binary"/>
180 <element name="X509SubjectName" type="string"/>
181 <element name="X509Certificate" type="base64Binary"/>
182 <element name="X509CRL" type="base64Binary"/>
183 <any namespace="##other" processContents="lax"/>
184 </choice>
185 </sequence>
186</complexType>
187
188<complexType name="X509IssuerSerialType">
189 <sequence>
190 <element name="X509IssuerName" type="string"/>
191 <element name="X509SerialNumber" type="integer"/>
192 </sequence>
193</complexType>
194
195<!-- End X509Data -->
196
197<!-- Begin PGPData -->
198
199<element name="PGPData" type="ds:PGPDataType"/>
200<complexType name="PGPDataType">
201 <choice>
202 <sequence>
203 <element name="PGPKeyID" type="base64Binary"/>
204 <element name="PGPKeyPacket" type="base64Binary" minOccurs="0"/>
205 <any namespace="##other" processContents="lax" minOccurs="0"
206 maxOccurs="unbounded"/>
207 </sequence>
208 <sequence>
209 <element name="PGPKeyPacket" type="base64Binary"/>
210 <any namespace="##other" processContents="lax" minOccurs="0"
211 maxOccurs="unbounded"/>
212 </sequence>
213 </choice>
214</complexType>
215
216<!-- End PGPData -->
217
218<!-- Begin SPKIData -->
219
220<element name="SPKIData" type="ds:SPKIDataType"/>
221<complexType name="SPKIDataType">
222 <sequence maxOccurs="unbounded">
223 <element name="SPKISexp" type="base64Binary"/>
224 <any namespace="##other" processContents="lax" minOccurs="0"/>
225 </sequence>
226</complexType>
227
228<!-- End SPKIData -->
229
230<!-- End KeyInfo -->
231
232<!-- Start Object (Manifest, SignatureProperty) -->
233
234<element name="Object" type="ds:ObjectType"/>
235<complexType name="ObjectType" mixed="true">
236 <sequence minOccurs="0" maxOccurs="unbounded">
237 <any namespace="##any" processContents="lax"/>
238 </sequence>
239 <attribute name="Id" type="ID" use="optional"/>
240 <attribute name="MimeType" type="string" use="optional"/> <!-- add a grep facet -->
241 <attribute name="Encoding" type="anyURI" use="optional"/>
242</complexType>
243
244<element name="Manifest" type="ds:ManifestType"/>
245<complexType name="ManifestType">
246 <sequence>
247 <element ref="ds:Reference" maxOccurs="unbounded"/>
248 </sequence>
249 <attribute name="Id" type="ID" use="optional"/>
250</complexType>
251
252<element name="SignatureProperties" type="ds:SignaturePropertiesType"/>
253<complexType name="SignaturePropertiesType">
254 <sequence>
255 <element ref="ds:SignatureProperty" maxOccurs="unbounded"/>
256 </sequence>
257 <attribute name="Id" type="ID" use="optional"/>
258</complexType>
259
260 <element name="SignatureProperty" type="ds:SignaturePropertyType"/>
261 <complexType name="SignaturePropertyType" mixed="true">
262 <choice maxOccurs="unbounded">
263 <any namespace="##other" processContents="lax"/>
264 <!-- (1,1) elements from (1,unbounded) namespaces -->
265 </choice>
266 <attribute name="Target" type="anyURI" use="required"/>
267 <attribute name="Id" type="ID" use="optional"/>
268 </complexType>
269
270<!-- End Object (Manifest, SignatureProperty) -->
271
272<!-- Start Algorithm Parameters -->
273
274<simpleType name="HMACOutputLengthType">
275 <restriction base="integer"/>
276</simpleType>
277
278<!-- Start KeyValue Element-types -->
279
280<element name="DSAKeyValue" type="ds:DSAKeyValueType"/>
281<complexType name="DSAKeyValueType">
282 <sequence>
283 <sequence minOccurs="0">
284 <element name="P" type="ds:CryptoBinary"/>
285 <element name="Q" type="ds:CryptoBinary"/>
286 </sequence>
287 <element name="G" type="ds:CryptoBinary" minOccurs="0"/>
288 <element name="Y" type="ds:CryptoBinary"/>
289 <element name="J" type="ds:CryptoBinary" minOccurs="0"/>
290 <sequence minOccurs="0">
291 <element name="Seed" type="ds:CryptoBinary"/>
292 <element name="PgenCounter" type="ds:CryptoBinary"/>
293 </sequence>
294 </sequence>
295</complexType>
296
297<element name="RSAKeyValue" type="ds:RSAKeyValueType"/>
298<complexType name="RSAKeyValueType">
299 <sequence>
300 <element name="Modulus" type="ds:CryptoBinary"/>
301 <element name="Exponent" type="ds:CryptoBinary"/>
302 </sequence>
303</complexType>
304
305<!-- End KeyValue Element-types -->
306
307<!-- End Signature -->
308
309</schema>