saml-kit 0.1.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (60) hide show
  1. checksums.yaml +7 -0
  2. data/.gitignore +12 -0
  3. data/.rspec +2 -0
  4. data/.travis.yml +5 -0
  5. data/Gemfile +6 -0
  6. data/LICENSE.txt +21 -0
  7. data/README.md +39 -0
  8. data/Rakefile +6 -0
  9. data/bin/console +14 -0
  10. data/bin/setup +8 -0
  11. data/exe/saml-kit-decode-http-redirect +7 -0
  12. data/lib/saml/kit.rb +60 -0
  13. data/lib/saml/kit/authentication_request.rb +78 -0
  14. data/lib/saml/kit/binding.rb +40 -0
  15. data/lib/saml/kit/configuration.rb +36 -0
  16. data/lib/saml/kit/default_registry.rb +49 -0
  17. data/lib/saml/kit/document.rb +96 -0
  18. data/lib/saml/kit/fingerprint.rb +40 -0
  19. data/lib/saml/kit/http_post_binding.rb +27 -0
  20. data/lib/saml/kit/http_redirect_binding.rb +58 -0
  21. data/lib/saml/kit/identity_provider_metadata.rb +122 -0
  22. data/lib/saml/kit/invalid_document.rb +13 -0
  23. data/lib/saml/kit/locales/en.yml +25 -0
  24. data/lib/saml/kit/logout_request.rb +78 -0
  25. data/lib/saml/kit/logout_response.rb +63 -0
  26. data/lib/saml/kit/metadata.rb +171 -0
  27. data/lib/saml/kit/namespaces.rb +47 -0
  28. data/lib/saml/kit/requestable.rb +14 -0
  29. data/lib/saml/kit/respondable.rb +35 -0
  30. data/lib/saml/kit/response.rb +197 -0
  31. data/lib/saml/kit/self_signed_certificate.rb +30 -0
  32. data/lib/saml/kit/serializable.rb +31 -0
  33. data/lib/saml/kit/service_provider_metadata.rb +99 -0
  34. data/lib/saml/kit/signature.rb +75 -0
  35. data/lib/saml/kit/trustable.rb +62 -0
  36. data/lib/saml/kit/url_builder.rb +38 -0
  37. data/lib/saml/kit/version.rb +5 -0
  38. data/lib/saml/kit/xml.rb +57 -0
  39. data/lib/saml/kit/xsd/MetadataExchange.xsd +95 -0
  40. data/lib/saml/kit/xsd/oasis-200401-wss-wssecurity-secext-1.0.xsd +196 -0
  41. data/lib/saml/kit/xsd/oasis-200401-wss-wssecurity-utility-1.0.xsd +95 -0
  42. data/lib/saml/kit/xsd/saml-schema-assertion-2.0.xsd +283 -0
  43. data/lib/saml/kit/xsd/saml-schema-authn-context-2.0.xsd +23 -0
  44. data/lib/saml/kit/xsd/saml-schema-authn-context-types-2.0.xsd +821 -0
  45. data/lib/saml/kit/xsd/saml-schema-metadata-2.0.xsd +335 -0
  46. data/lib/saml/kit/xsd/saml-schema-protocol-2.0.xsd +302 -0
  47. data/lib/saml/kit/xsd/sstc-metadata-attr.xsd +35 -0
  48. data/lib/saml/kit/xsd/sstc-saml-attribute-ext.xsd +25 -0
  49. data/lib/saml/kit/xsd/sstc-saml-metadata-algsupport-v1.0.xsd +41 -0
  50. data/lib/saml/kit/xsd/sstc-saml-metadata-ui-v1.0.xsd +89 -0
  51. data/lib/saml/kit/xsd/ws-addr.xsd +120 -0
  52. data/lib/saml/kit/xsd/ws-authorization.xsd +145 -0
  53. data/lib/saml/kit/xsd/ws-federation.xsd +471 -0
  54. data/lib/saml/kit/xsd/ws-securitypolicy-1.2.xsd +900 -0
  55. data/lib/saml/kit/xsd/xenc-schema.xsd +136 -0
  56. data/lib/saml/kit/xsd/xml.xsd +287 -0
  57. data/lib/saml/kit/xsd/xmldsig-core-schema.xsd +309 -0
  58. data/lib/saml/kit/xsd_validatable.rb +19 -0
  59. data/saml-kit.gemspec +35 -0
  60. metadata +243 -0
@@ -0,0 +1,95 @@
1
+ <?xml version="1.0" encoding="UTF-8"?>
2
+ <!--
3
+
4
+ OASIS takes no position regarding the validity or scope of any intellectual property or other rights that might be claimed to pertain to the implementation or use of the technology described in this document or the extent to which any license under such rights might or might not be available; neither does it represent that it has made any effort to identify any such rights. Information on OASIS's procedures with respect to rights in OASIS specifications can be found at the OASIS website. Copies of claims of rights made available for publication and any assurances of licenses to be made available, or the result of an attempt made to obtain a general license or permission for the use of such proprietary rights by implementors or users of this specification, can be obtained from the OASIS Executive Director.
5
+ OASIS invites any interested party to bring to its attention any copyrights, patents or patent applications, or other proprietary rights which may cover technology that may be required to implement this specification. Please address the information to the OASIS Executive Director.
6
+ Copyright © OASIS Open 2002-2004. All Rights Reserved.
7
+ This document and translations of it may be copied and furnished to others, and derivative works that comment on or otherwise explain it or assist in its implementation may be prepared, copied, published and distributed, in whole or in part, without restriction of any kind, provided that the above copyright notice and this paragraph are included on all such copies and derivative works. However, this document itself does not be modified in any way, such as by removing the copyright notice or references to OASIS, except as needed for the purpose of developing OASIS specifications, in which case the procedures for copyrights defined in the OASIS Intellectual Property Rights document must be followed, or as required to translate it into languages other than English.
8
+ The limited permissions granted above are perpetual and will not be revoked by OASIS or its successors or assigns.
9
+ This document and the information contained herein is provided on an “AS IS” basis and OASIS DISCLAIMS ALL WARRANTIES, EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO ANY WARRANTY THAT THE USE OF THE INFORMATION HEREIN WILL NOT INFRINGE ANY RIGHTS OR ANY IMPLIED WARRANTIES OF MERCHANTABILITY OR FITNESS FOR A PARTICULAR PURPOSE.
10
+ -->
11
+ <xsd:schema xmlns:xsd="http://www.w3.org/2001/XMLSchema" xmlns="http://docs.oasis-open.org/wss/2004/01/oasis-200401-wss-wssecurity-utility-1.0.xsd" xmlns:wsu="http://docs.oasis-open.org/wss/2004/01/oasis-200401-wss-wssecurity-utility-1.0.xsd" targetNamespace="http://docs.oasis-open.org/wss/2004/01/oasis-200401-wss-wssecurity-utility-1.0.xsd" elementFormDefault="qualified" attributeFormDefault="unqualified" version="0.1">
12
+ <!--
13
+ // Fault Codes ///////////////////////////////////////////
14
+ -->
15
+ <xsd:simpleType name="tTimestampFault">
16
+ <xsd:annotation>
17
+ <xsd:documentation>This type defines the fault code value for Timestamp message expiration.</xsd:documentation>
18
+ </xsd:annotation>
19
+ <xsd:restriction base="xsd:QName">
20
+ <xsd:enumeration value="wsu:MessageExpired" />
21
+ </xsd:restriction>
22
+ </xsd:simpleType>
23
+ <!--
24
+ // Global attributes ////////////////////////////////////
25
+ -->
26
+ <xsd:attribute name="Id" type="xsd:ID">
27
+ <xsd:annotation>
28
+ <xsd:documentation>This global attribute supports annotating arbitrary elements with an ID.</xsd:documentation>
29
+ </xsd:annotation>
30
+ </xsd:attribute>
31
+ <xsd:attributeGroup name="commonAtts">
32
+ <xsd:annotation>
33
+ <xsd:documentation>Convenience attribute group used to simplify this schema.</xsd:documentation>
34
+ </xsd:annotation>
35
+ <xsd:attribute ref="wsu:Id" use="optional" />
36
+ <xsd:anyAttribute namespace="##other" processContents="lax" />
37
+ </xsd:attributeGroup>
38
+ <!--
39
+ // Utility types ////////////////////////////////////////
40
+ -->
41
+ <xsd:complexType name="AttributedDateTime">
42
+ <xsd:annotation>
43
+ <xsd:documentation>This type is for elements whose [children] is a psuedo-dateTime and can have arbitrary attributes.</xsd:documentation>
44
+ </xsd:annotation>
45
+ <xsd:simpleContent>
46
+ <xsd:extension base="xsd:string">
47
+ <xsd:attributeGroup ref="wsu:commonAtts" />
48
+ </xsd:extension>
49
+ </xsd:simpleContent>
50
+ </xsd:complexType>
51
+ <xsd:complexType name="AttributedURI">
52
+ <xsd:annotation>
53
+ <xsd:documentation>This type is for elements whose [children] is an anyURI and can have arbitrary attributes.</xsd:documentation>
54
+ </xsd:annotation>
55
+ <xsd:simpleContent>
56
+ <xsd:extension base="xsd:anyURI">
57
+ <xsd:attributeGroup ref="wsu:commonAtts" />
58
+ </xsd:extension>
59
+ </xsd:simpleContent>
60
+ </xsd:complexType>
61
+ <!--
62
+ // Timestamp header components ///////////////////////////
63
+ -->
64
+ <xsd:complexType name="TimestampType">
65
+ <xsd:annotation>
66
+ <xsd:documentation>This complex type ties together the timestamp related elements into a composite type.</xsd:documentation>
67
+ </xsd:annotation>
68
+ <xsd:sequence>
69
+ <xsd:element ref="wsu:Created" minOccurs="0" />
70
+ <xsd:element ref="wsu:Expires" minOccurs="0" />
71
+ <xsd:choice minOccurs="0" maxOccurs="unbounded">
72
+ <xsd:any namespace="##other" processContents="lax" />
73
+ </xsd:choice>
74
+ </xsd:sequence>
75
+ <xsd:attributeGroup ref="wsu:commonAtts" />
76
+ </xsd:complexType>
77
+ <xsd:element name="Timestamp" type="wsu:TimestampType">
78
+ <xsd:annotation>
79
+ <xsd:documentation>This element allows Timestamps to be applied anywhere element wildcards are present, including as a SOAP header.</xsd:documentation>
80
+ </xsd:annotation>
81
+ </xsd:element>
82
+ <!--
83
+ global element decls to allow individual elements to appear anywhere
84
+ -->
85
+ <xsd:element name="Expires" type="wsu:AttributedDateTime">
86
+ <xsd:annotation>
87
+ <xsd:documentation>This element allows an expiration time to be applied anywhere element wildcards are present.</xsd:documentation>
88
+ </xsd:annotation>
89
+ </xsd:element>
90
+ <xsd:element name="Created" type="wsu:AttributedDateTime">
91
+ <xsd:annotation>
92
+ <xsd:documentation>This element allows a creation time to be applied anywhere element wildcards are present.</xsd:documentation>
93
+ </xsd:annotation>
94
+ </xsd:element>
95
+ </xsd:schema>
@@ -0,0 +1,283 @@
1
+ <?xml version="1.0" encoding="US-ASCII"?>
2
+ <schema
3
+ targetNamespace="urn:oasis:names:tc:SAML:2.0:assertion"
4
+ xmlns="http://www.w3.org/2001/XMLSchema"
5
+ xmlns:saml="urn:oasis:names:tc:SAML:2.0:assertion"
6
+ xmlns:ds="http://www.w3.org/2000/09/xmldsig#"
7
+ xmlns:xenc="http://www.w3.org/2001/04/xmlenc#"
8
+ elementFormDefault="unqualified"
9
+ attributeFormDefault="unqualified"
10
+ blockDefault="substitution"
11
+ version="2.0">
12
+ <import namespace="http://www.w3.org/2000/09/xmldsig#"
13
+ schemaLocation="xmldsig-core-schema.xsd"/>
14
+ <import namespace="http://www.w3.org/2001/04/xmlenc#"
15
+ schemaLocation="xenc-schema.xsd"/>
16
+ <annotation>
17
+ <documentation>
18
+ Document identifier: saml-schema-assertion-2.0
19
+ Location: http://docs.oasis-open.org/security/saml/v2.0/
20
+ Revision history:
21
+ V1.0 (November, 2002):
22
+ Initial Standard Schema.
23
+ V1.1 (September, 2003):
24
+ Updates within the same V1.0 namespace.
25
+ V2.0 (March, 2005):
26
+ New assertion schema for SAML V2.0 namespace.
27
+ </documentation>
28
+ </annotation>
29
+ <attributeGroup name="IDNameQualifiers">
30
+ <attribute name="NameQualifier" type="string" use="optional"/>
31
+ <attribute name="SPNameQualifier" type="string" use="optional"/>
32
+ </attributeGroup>
33
+ <element name="BaseID" type="saml:BaseIDAbstractType"/>
34
+ <complexType name="BaseIDAbstractType" abstract="true">
35
+ <attributeGroup ref="saml:IDNameQualifiers"/>
36
+ </complexType>
37
+ <element name="NameID" type="saml:NameIDType"/>
38
+ <complexType name="NameIDType">
39
+ <simpleContent>
40
+ <extension base="string">
41
+ <attributeGroup ref="saml:IDNameQualifiers"/>
42
+ <attribute name="Format" type="anyURI" use="optional"/>
43
+ <attribute name="SPProvidedID" type="string" use="optional"/>
44
+ </extension>
45
+ </simpleContent>
46
+ </complexType>
47
+ <complexType name="EncryptedElementType">
48
+ <sequence>
49
+ <element ref="xenc:EncryptedData"/>
50
+ <element ref="xenc:EncryptedKey" minOccurs="0" maxOccurs="unbounded"/>
51
+ </sequence>
52
+ </complexType>
53
+ <element name="EncryptedID" type="saml:EncryptedElementType"/>
54
+ <element name="Issuer" type="saml:NameIDType"/>
55
+ <element name="AssertionIDRef" type="NCName"/>
56
+ <element name="AssertionURIRef" type="anyURI"/>
57
+ <element name="Assertion" type="saml:AssertionType"/>
58
+ <complexType name="AssertionType">
59
+ <sequence>
60
+ <element ref="saml:Issuer"/>
61
+ <element ref="ds:Signature" minOccurs="0"/>
62
+ <element ref="saml:Subject" minOccurs="0"/>
63
+ <element ref="saml:Conditions" minOccurs="0"/>
64
+ <element ref="saml:Advice" minOccurs="0"/>
65
+ <choice minOccurs="0" maxOccurs="unbounded">
66
+ <element ref="saml:Statement"/>
67
+ <element ref="saml:AuthnStatement"/>
68
+ <element ref="saml:AuthzDecisionStatement"/>
69
+ <element ref="saml:AttributeStatement"/>
70
+ </choice>
71
+ </sequence>
72
+ <attribute name="Version" type="string" use="required"/>
73
+ <attribute name="ID" type="ID" use="required"/>
74
+ <attribute name="IssueInstant" type="dateTime" use="required"/>
75
+ </complexType>
76
+ <element name="Subject" type="saml:SubjectType"/>
77
+ <complexType name="SubjectType">
78
+ <choice>
79
+ <sequence>
80
+ <choice>
81
+ <element ref="saml:BaseID"/>
82
+ <element ref="saml:NameID"/>
83
+ <element ref="saml:EncryptedID"/>
84
+ </choice>
85
+ <element ref="saml:SubjectConfirmation" minOccurs="0" maxOccurs="unbounded"/>
86
+ </sequence>
87
+ <element ref="saml:SubjectConfirmation" maxOccurs="unbounded"/>
88
+ </choice>
89
+ </complexType>
90
+ <element name="SubjectConfirmation" type="saml:SubjectConfirmationType"/>
91
+ <complexType name="SubjectConfirmationType">
92
+ <sequence>
93
+ <choice minOccurs="0">
94
+ <element ref="saml:BaseID"/>
95
+ <element ref="saml:NameID"/>
96
+ <element ref="saml:EncryptedID"/>
97
+ </choice>
98
+ <element ref="saml:SubjectConfirmationData" minOccurs="0"/>
99
+ </sequence>
100
+ <attribute name="Method" type="anyURI" use="required"/>
101
+ </complexType>
102
+ <element name="SubjectConfirmationData" type="saml:SubjectConfirmationDataType"/>
103
+ <complexType name="SubjectConfirmationDataType" mixed="true">
104
+ <complexContent>
105
+ <restriction base="anyType">
106
+ <sequence>
107
+ <any namespace="##any" processContents="lax" minOccurs="0" maxOccurs="unbounded"/>
108
+ </sequence>
109
+ <attribute name="NotBefore" type="dateTime" use="optional"/>
110
+ <attribute name="NotOnOrAfter" type="dateTime" use="optional"/>
111
+ <attribute name="Recipient" type="anyURI" use="optional"/>
112
+ <attribute name="InResponseTo" type="NCName" use="optional"/>
113
+ <attribute name="Address" type="string" use="optional"/>
114
+ <anyAttribute namespace="##other" processContents="lax"/>
115
+ </restriction>
116
+ </complexContent>
117
+ </complexType>
118
+ <complexType name="KeyInfoConfirmationDataType" mixed="false">
119
+ <complexContent>
120
+ <restriction base="saml:SubjectConfirmationDataType">
121
+ <sequence>
122
+ <element ref="ds:KeyInfo" maxOccurs="unbounded"/>
123
+ </sequence>
124
+ </restriction>
125
+ </complexContent>
126
+ </complexType>
127
+ <element name="Conditions" type="saml:ConditionsType"/>
128
+ <complexType name="ConditionsType">
129
+ <choice minOccurs="0" maxOccurs="unbounded">
130
+ <element ref="saml:Condition"/>
131
+ <element ref="saml:AudienceRestriction"/>
132
+ <element ref="saml:OneTimeUse"/>
133
+ <element ref="saml:ProxyRestriction"/>
134
+ </choice>
135
+ <attribute name="NotBefore" type="dateTime" use="optional"/>
136
+ <attribute name="NotOnOrAfter" type="dateTime" use="optional"/>
137
+ </complexType>
138
+ <element name="Condition" type="saml:ConditionAbstractType"/>
139
+ <complexType name="ConditionAbstractType" abstract="true"/>
140
+ <element name="AudienceRestriction" type="saml:AudienceRestrictionType"/>
141
+ <complexType name="AudienceRestrictionType">
142
+ <complexContent>
143
+ <extension base="saml:ConditionAbstractType">
144
+ <sequence>
145
+ <element ref="saml:Audience" maxOccurs="unbounded"/>
146
+ </sequence>
147
+ </extension>
148
+ </complexContent>
149
+ </complexType>
150
+ <element name="Audience" type="anyURI"/>
151
+ <element name="OneTimeUse" type="saml:OneTimeUseType" />
152
+ <complexType name="OneTimeUseType">
153
+ <complexContent>
154
+ <extension base="saml:ConditionAbstractType"/>
155
+ </complexContent>
156
+ </complexType>
157
+ <element name="ProxyRestriction" type="saml:ProxyRestrictionType"/>
158
+ <complexType name="ProxyRestrictionType">
159
+ <complexContent>
160
+ <extension base="saml:ConditionAbstractType">
161
+ <sequence>
162
+ <element ref="saml:Audience" minOccurs="0" maxOccurs="unbounded"/>
163
+ </sequence>
164
+ <attribute name="Count" type="nonNegativeInteger" use="optional"/>
165
+ </extension>
166
+ </complexContent>
167
+ </complexType>
168
+ <element name="Advice" type="saml:AdviceType"/>
169
+ <complexType name="AdviceType">
170
+ <choice minOccurs="0" maxOccurs="unbounded">
171
+ <element ref="saml:AssertionIDRef"/>
172
+ <element ref="saml:AssertionURIRef"/>
173
+ <element ref="saml:Assertion"/>
174
+ <element ref="saml:EncryptedAssertion"/>
175
+ <any namespace="##other" processContents="lax"/>
176
+ </choice>
177
+ </complexType>
178
+ <element name="EncryptedAssertion" type="saml:EncryptedElementType"/>
179
+ <element name="Statement" type="saml:StatementAbstractType"/>
180
+ <complexType name="StatementAbstractType" abstract="true"/>
181
+ <element name="AuthnStatement" type="saml:AuthnStatementType"/>
182
+ <complexType name="AuthnStatementType">
183
+ <complexContent>
184
+ <extension base="saml:StatementAbstractType">
185
+ <sequence>
186
+ <element ref="saml:SubjectLocality" minOccurs="0"/>
187
+ <element ref="saml:AuthnContext"/>
188
+ </sequence>
189
+ <attribute name="AuthnInstant" type="dateTime" use="required"/>
190
+ <attribute name="SessionIndex" type="string" use="optional"/>
191
+ <attribute name="SessionNotOnOrAfter" type="dateTime" use="optional"/>
192
+ </extension>
193
+ </complexContent>
194
+ </complexType>
195
+ <element name="SubjectLocality" type="saml:SubjectLocalityType"/>
196
+ <complexType name="SubjectLocalityType">
197
+ <attribute name="Address" type="string" use="optional"/>
198
+ <attribute name="DNSName" type="string" use="optional"/>
199
+ </complexType>
200
+ <element name="AuthnContext" type="saml:AuthnContextType"/>
201
+ <complexType name="AuthnContextType">
202
+ <sequence>
203
+ <choice>
204
+ <sequence>
205
+ <element ref="saml:AuthnContextClassRef"/>
206
+ <choice minOccurs="0">
207
+ <element ref="saml:AuthnContextDecl"/>
208
+ <element ref="saml:AuthnContextDeclRef"/>
209
+ </choice>
210
+ </sequence>
211
+ <choice>
212
+ <element ref="saml:AuthnContextDecl"/>
213
+ <element ref="saml:AuthnContextDeclRef"/>
214
+ </choice>
215
+ </choice>
216
+ <element ref="saml:AuthenticatingAuthority" minOccurs="0" maxOccurs="unbounded"/>
217
+ </sequence>
218
+ </complexType>
219
+ <element name="AuthnContextClassRef" type="anyURI"/>
220
+ <element name="AuthnContextDeclRef" type="anyURI"/>
221
+ <element name="AuthnContextDecl" type="anyType"/>
222
+ <element name="AuthenticatingAuthority" type="anyURI"/>
223
+ <element name="AuthzDecisionStatement" type="saml:AuthzDecisionStatementType"/>
224
+ <complexType name="AuthzDecisionStatementType">
225
+ <complexContent>
226
+ <extension base="saml:StatementAbstractType">
227
+ <sequence>
228
+ <element ref="saml:Action" maxOccurs="unbounded"/>
229
+ <element ref="saml:Evidence" minOccurs="0"/>
230
+ </sequence>
231
+ <attribute name="Resource" type="anyURI" use="required"/>
232
+ <attribute name="Decision" type="saml:DecisionType" use="required"/>
233
+ </extension>
234
+ </complexContent>
235
+ </complexType>
236
+ <simpleType name="DecisionType">
237
+ <restriction base="string">
238
+ <enumeration value="Permit"/>
239
+ <enumeration value="Deny"/>
240
+ <enumeration value="Indeterminate"/>
241
+ </restriction>
242
+ </simpleType>
243
+ <element name="Action" type="saml:ActionType"/>
244
+ <complexType name="ActionType">
245
+ <simpleContent>
246
+ <extension base="string">
247
+ <attribute name="Namespace" type="anyURI" use="required"/>
248
+ </extension>
249
+ </simpleContent>
250
+ </complexType>
251
+ <element name="Evidence" type="saml:EvidenceType"/>
252
+ <complexType name="EvidenceType">
253
+ <choice maxOccurs="unbounded">
254
+ <element ref="saml:AssertionIDRef"/>
255
+ <element ref="saml:AssertionURIRef"/>
256
+ <element ref="saml:Assertion"/>
257
+ <element ref="saml:EncryptedAssertion"/>
258
+ </choice>
259
+ </complexType>
260
+ <element name="AttributeStatement" type="saml:AttributeStatementType"/>
261
+ <complexType name="AttributeStatementType">
262
+ <complexContent>
263
+ <extension base="saml:StatementAbstractType">
264
+ <choice maxOccurs="unbounded">
265
+ <element ref="saml:Attribute"/>
266
+ <element ref="saml:EncryptedAttribute"/>
267
+ </choice>
268
+ </extension>
269
+ </complexContent>
270
+ </complexType>
271
+ <element name="Attribute" type="saml:AttributeType"/>
272
+ <complexType name="AttributeType">
273
+ <sequence>
274
+ <element ref="saml:AttributeValue" minOccurs="0" maxOccurs="unbounded"/>
275
+ </sequence>
276
+ <attribute name="Name" type="string" use="required"/>
277
+ <attribute name="NameFormat" type="anyURI" use="optional"/>
278
+ <attribute name="FriendlyName" type="string" use="optional"/>
279
+ <anyAttribute namespace="##other" processContents="lax"/>
280
+ </complexType>
281
+ <element name="AttributeValue" type="anyType" nillable="true"/>
282
+ <element name="EncryptedAttribute" type="saml:EncryptedElementType"/>
283
+ </schema>
@@ -0,0 +1,23 @@
1
+ <?xml version="1.0" encoding="UTF-8"?>
2
+ <xs:schema
3
+ targetNamespace="urn:oasis:names:tc:SAML:2.0:ac"
4
+ xmlns:xs="http://www.w3.org/2001/XMLSchema"
5
+ xmlns="urn:oasis:names:tc:SAML:2.0:ac"
6
+ blockDefault="substitution"
7
+ version="2.0">
8
+
9
+ <xs:annotation>
10
+ <xs:documentation>
11
+ Document identifier: saml-schema-authn-context-2.0
12
+ Location: http://docs.oasis-open.org/security/saml/v2.0/
13
+ Revision history:
14
+ V2.0 (March, 2005):
15
+ New core authentication context schema for SAML V2.0.
16
+ This is just an include of all types from the schema
17
+ referred to in the include statement below.
18
+ </xs:documentation>
19
+ </xs:annotation>
20
+
21
+ <xs:include schemaLocation="saml-schema-authn-context-types-2.0.xsd"/>
22
+
23
+ </xs:schema>
@@ -0,0 +1,821 @@
1
+ <?xml version="1.0" encoding="UTF-8"?>
2
+ <xs:schema
3
+ xmlns:xs="http://www.w3.org/2001/XMLSchema"
4
+ elementFormDefault="qualified"
5
+ version="2.0">
6
+
7
+ <xs:annotation>
8
+ <xs:documentation>
9
+ Document identifier: saml-schema-authn-context-types-2.0
10
+ Location: http://docs.oasis-open.org/security/saml/v2.0/
11
+ Revision history:
12
+ V2.0 (March, 2005):
13
+ New core authentication context schema types for SAML V2.0.
14
+ </xs:documentation>
15
+ </xs:annotation>
16
+
17
+ <xs:element name="AuthenticationContextDeclaration" type="AuthnContextDeclarationBaseType">
18
+ <xs:annotation>
19
+ <xs:documentation>
20
+ A particular assertion on an identity
21
+ provider's part with respect to the authentication
22
+ context associated with an authentication assertion.
23
+ </xs:documentation>
24
+ </xs:annotation>
25
+ </xs:element>
26
+
27
+ <xs:element name="Identification" type="IdentificationType">
28
+ <xs:annotation>
29
+ <xs:documentation>
30
+ Refers to those characteristics that describe the
31
+ processes and mechanisms
32
+ the Authentication Authority uses to initially create
33
+ an association between a Principal
34
+ and the identity (or name) by which the Principal will
35
+ be known
36
+ </xs:documentation>
37
+ </xs:annotation>
38
+ </xs:element>
39
+
40
+ <xs:element name="PhysicalVerification">
41
+ <xs:annotation>
42
+ <xs:documentation>
43
+ This element indicates that identification has been
44
+ performed in a physical
45
+ face-to-face meeting with the principal and not in an
46
+ online manner.
47
+ </xs:documentation>
48
+ </xs:annotation>
49
+ <xs:complexType>
50
+ <xs:attribute name="credentialLevel">
51
+ <xs:simpleType>
52
+ <xs:restriction base="xs:NMTOKEN">
53
+ <xs:enumeration value="primary"/>
54
+ <xs:enumeration value="secondary"/>
55
+ </xs:restriction>
56
+ </xs:simpleType>
57
+ </xs:attribute>
58
+ </xs:complexType>
59
+ </xs:element>
60
+
61
+ <xs:element name="WrittenConsent" type="ExtensionOnlyType"/>
62
+
63
+ <xs:element name="TechnicalProtection" type="TechnicalProtectionBaseType">
64
+ <xs:annotation>
65
+ <xs:documentation>
66
+ Refers to those characterstics that describe how the
67
+ 'secret' (the knowledge or possession
68
+ of which allows the Principal to authenticate to the
69
+ Authentication Authority) is kept secure
70
+ </xs:documentation>
71
+ </xs:annotation>
72
+ </xs:element>
73
+
74
+ <xs:element name="SecretKeyProtection" type="SecretKeyProtectionType">
75
+ <xs:annotation>
76
+ <xs:documentation>
77
+ This element indicates the types and strengths of
78
+ facilities
79
+ of a UA used to protect a shared secret key from
80
+ unauthorized access and/or use.
81
+ </xs:documentation>
82
+ </xs:annotation>
83
+ </xs:element>
84
+
85
+ <xs:element name="PrivateKeyProtection" type="PrivateKeyProtectionType">
86
+ <xs:annotation>
87
+ <xs:documentation>
88
+ This element indicates the types and strengths of
89
+ facilities
90
+ of a UA used to protect a private key from
91
+ unauthorized access and/or use.
92
+ </xs:documentation>
93
+ </xs:annotation>
94
+ </xs:element>
95
+
96
+ <xs:element name="KeyActivation" type="KeyActivationType">
97
+ <xs:annotation>
98
+ <xs:documentation>The actions that must be performed
99
+ before the private key can be used. </xs:documentation>
100
+ </xs:annotation>
101
+ </xs:element>
102
+
103
+ <xs:element name="KeySharing" type="KeySharingType">
104
+ <xs:annotation>
105
+ <xs:documentation>Whether or not the private key is shared
106
+ with the certificate authority.</xs:documentation>
107
+ </xs:annotation>
108
+ </xs:element>
109
+
110
+ <xs:element name="KeyStorage" type="KeyStorageType">
111
+ <xs:annotation>
112
+ <xs:documentation>
113
+ In which medium is the key stored.
114
+ memory - the key is stored in memory.
115
+ smartcard - the key is stored in a smartcard.
116
+ token - the key is stored in a hardware token.
117
+ MobileDevice - the key is stored in a mobile device.
118
+ MobileAuthCard - the key is stored in a mobile
119
+ authentication card.
120
+ </xs:documentation>
121
+ </xs:annotation>
122
+ </xs:element>
123
+
124
+ <xs:element name="SubscriberLineNumber" type="ExtensionOnlyType"/>
125
+ <xs:element name="UserSuffix" type="ExtensionOnlyType"/>
126
+
127
+ <xs:element name="Password" type="PasswordType">
128
+ <xs:annotation>
129
+ <xs:documentation>
130
+ This element indicates that a password (or passphrase)
131
+ has been used to
132
+ authenticate the Principal to a remote system.
133
+ </xs:documentation>
134
+ </xs:annotation>
135
+ </xs:element>
136
+
137
+ <xs:element name="ActivationPin" type="ActivationPinType">
138
+ <xs:annotation>
139
+ <xs:documentation>
140
+ This element indicates that a Pin (Personal
141
+ Identification Number) has been used to authenticate the Principal to
142
+ some local system in order to activate a key.
143
+ </xs:documentation>
144
+ </xs:annotation>
145
+ </xs:element>
146
+
147
+ <xs:element name="Token" type="TokenType">
148
+ <xs:annotation>
149
+ <xs:documentation>
150
+ This element indicates that a hardware or software
151
+ token is used
152
+ as a method of identifying the Principal.
153
+ </xs:documentation>
154
+ </xs:annotation>
155
+ </xs:element>
156
+
157
+ <xs:element name="TimeSyncToken" type="TimeSyncTokenType">
158
+ <xs:annotation>
159
+ <xs:documentation>
160
+ This element indicates that a time synchronization
161
+ token is used to identify the Principal. hardware -
162
+ the time synchonization
163
+ token has been implemented in hardware. software - the
164
+ time synchronization
165
+ token has been implemented in software. SeedLength -
166
+ the length, in bits, of the
167
+ random seed used in the time synchronization token.
168
+ </xs:documentation>
169
+ </xs:annotation>
170
+ </xs:element>
171
+
172
+ <xs:element name="Smartcard" type="ExtensionOnlyType">
173
+ <xs:annotation>
174
+ <xs:documentation>
175
+ This element indicates that a smartcard is used to
176
+ identity the Principal.
177
+ </xs:documentation>
178
+ </xs:annotation>
179
+ </xs:element>
180
+
181
+ <xs:element name="Length" type="LengthType">
182
+ <xs:annotation>
183
+ <xs:documentation>
184
+ This element indicates the minimum and/or maximum
185
+ ASCII length of the password which is enforced (by the UA or the
186
+ IdP). In other words, this is the minimum and/or maximum number of
187
+ ASCII characters required to represent a valid password.
188
+ min - the minimum number of ASCII characters required
189
+ in a valid password, as enforced by the UA or the IdP.
190
+ max - the maximum number of ASCII characters required
191
+ in a valid password, as enforced by the UA or the IdP.
192
+ </xs:documentation>
193
+ </xs:annotation>
194
+ </xs:element>
195
+
196
+ <xs:element name="ActivationLimit" type="ActivationLimitType">
197
+ <xs:annotation>
198
+ <xs:documentation>
199
+ This element indicates the length of time for which an
200
+ PIN-based authentication is valid.
201
+ </xs:documentation>
202
+ </xs:annotation>
203
+ </xs:element>
204
+
205
+ <xs:element name="Generation">
206
+ <xs:annotation>
207
+ <xs:documentation>
208
+ Indicates whether the password was chosen by the
209
+ Principal or auto-supplied by the Authentication Authority.
210
+ principalchosen - the Principal is allowed to choose
211
+ the value of the password. This is true even if
212
+ the initial password is chosen at random by the UA or
213
+ the IdP and the Principal is then free to change
214
+ the password.
215
+ automatic - the password is chosen by the UA or the
216
+ IdP to be cryptographically strong in some sense,
217
+ or to satisfy certain password rules, and that the
218
+ Principal is not free to change it or to choose a new password.
219
+ </xs:documentation>
220
+ </xs:annotation>
221
+
222
+ <xs:complexType>
223
+ <xs:attribute name="mechanism" use="required">
224
+ <xs:simpleType>
225
+ <xs:restriction base="xs:NMTOKEN">
226
+ <xs:enumeration value="principalchosen"/>
227
+ <xs:enumeration value="automatic"/>
228
+ </xs:restriction>
229
+ </xs:simpleType>
230
+ </xs:attribute>
231
+ </xs:complexType>
232
+ </xs:element>
233
+
234
+ <xs:element name="AuthnMethod" type="AuthnMethodBaseType">
235
+ <xs:annotation>
236
+ <xs:documentation>
237
+ Refers to those characteristics that define the
238
+ mechanisms by which the Principal authenticates to the Authentication
239
+ Authority.
240
+ </xs:documentation>
241
+ </xs:annotation>
242
+ </xs:element>
243
+
244
+ <xs:element name="PrincipalAuthenticationMechanism" type="PrincipalAuthenticationMechanismType">
245
+ <xs:annotation>
246
+ <xs:documentation>
247
+ The method that a Principal employs to perform
248
+ authentication to local system components.
249
+ </xs:documentation>
250
+ </xs:annotation>
251
+ </xs:element>
252
+
253
+ <xs:element name="Authenticator" type="AuthenticatorBaseType">
254
+ <xs:annotation>
255
+ <xs:documentation>
256
+ The method applied to validate a principal's
257
+ authentication across a network
258
+ </xs:documentation>
259
+ </xs:annotation>
260
+ </xs:element>
261
+
262
+ <xs:element name="ComplexAuthenticator" type="ComplexAuthenticatorType">
263
+ <xs:annotation>
264
+ <xs:documentation>
265
+ Supports Authenticators with nested combinations of
266
+ additional complexity.
267
+ </xs:documentation>
268
+ </xs:annotation>
269
+ </xs:element>
270
+
271
+ <xs:element name="PreviousSession" type="ExtensionOnlyType">
272
+ <xs:annotation>
273
+ <xs:documentation>
274
+ Indicates that the Principal has been strongly
275
+ authenticated in a previous session during which the IdP has set a
276
+ cookie in the UA. During the present session the Principal has only
277
+ been authenticated by the UA returning the cookie to the IdP.
278
+ </xs:documentation>
279
+ </xs:annotation>
280
+ </xs:element>
281
+
282
+ <xs:element name="ResumeSession" type="ExtensionOnlyType">
283
+ <xs:annotation>
284
+ <xs:documentation>
285
+ Rather like PreviousSession but using stronger
286
+ security. A secret that was established in a previous session with
287
+ the Authentication Authority has been cached by the local system and
288
+ is now re-used (e.g. a Master Secret is used to derive new session
289
+ keys in TLS, SSL, WTLS).
290
+ </xs:documentation>
291
+ </xs:annotation>
292
+ </xs:element>
293
+
294
+ <xs:element name="ZeroKnowledge" type="ExtensionOnlyType">
295
+ <xs:annotation>
296
+ <xs:documentation>
297
+ This element indicates that the Principal has been
298
+ authenticated by a zero knowledge technique as specified in ISO/IEC
299
+ 9798-5.
300
+ </xs:documentation>
301
+ </xs:annotation>
302
+ </xs:element>
303
+
304
+ <xs:element name="SharedSecretChallengeResponse" type="SharedSecretChallengeResponseType"/>
305
+
306
+ <xs:complexType name="SharedSecretChallengeResponseType">
307
+ <xs:annotation>
308
+ <xs:documentation>
309
+ This element indicates that the Principal has been
310
+ authenticated by a challenge-response protocol utilizing shared secret
311
+ keys and symmetric cryptography.
312
+ </xs:documentation>
313
+ </xs:annotation>
314
+ <xs:sequence>
315
+ <xs:element ref="Extension" minOccurs="0" maxOccurs="unbounded"/>
316
+ </xs:sequence>
317
+ <xs:attribute name="method" type="xs:anyURI" use="optional"/>
318
+ </xs:complexType>
319
+
320
+ <xs:element name="DigSig" type="PublicKeyType">
321
+ <xs:annotation>
322
+ <xs:documentation>
323
+ This element indicates that the Principal has been
324
+ authenticated by a mechanism which involves the Principal computing a
325
+ digital signature over at least challenge data provided by the IdP.
326
+ </xs:documentation>
327
+ </xs:annotation>
328
+ </xs:element>
329
+
330
+ <xs:element name="AsymmetricDecryption" type="PublicKeyType">
331
+ <xs:annotation>
332
+ <xs:documentation>
333
+ The local system has a private key but it is used
334
+ in decryption mode, rather than signature mode. For example, the
335
+ Authentication Authority generates a secret and encrypts it using the
336
+ local system's public key: the local system then proves it has
337
+ decrypted the secret.
338
+ </xs:documentation>
339
+ </xs:annotation>
340
+ </xs:element>
341
+
342
+ <xs:element name="AsymmetricKeyAgreement" type="PublicKeyType">
343
+ <xs:annotation>
344
+ <xs:documentation>
345
+ The local system has a private key and uses it for
346
+ shared secret key agreement with the Authentication Authority (e.g.
347
+ via Diffie Helman).
348
+ </xs:documentation>
349
+ </xs:annotation>
350
+ </xs:element>
351
+
352
+ <xs:complexType name="PublicKeyType">
353
+ <xs:sequence>
354
+ <xs:element ref="Extension" minOccurs="0" maxOccurs="unbounded"/>
355
+ </xs:sequence>
356
+ <xs:attribute name="keyValidation" use="optional"/>
357
+ </xs:complexType>
358
+
359
+ <xs:element name="IPAddress" type="ExtensionOnlyType">
360
+ <xs:annotation>
361
+ <xs:documentation>
362
+ This element indicates that the Principal has been
363
+ authenticated through connection from a particular IP address.
364
+ </xs:documentation>
365
+ </xs:annotation>
366
+ </xs:element>
367
+
368
+ <xs:element name="SharedSecretDynamicPlaintext" type="ExtensionOnlyType">
369
+ <xs:annotation>
370
+ <xs:documentation>
371
+ The local system and Authentication Authority
372
+ share a secret key. The local system uses this to encrypt a
373
+ randomised string to pass to the Authentication Authority.
374
+ </xs:documentation>
375
+ </xs:annotation>
376
+ </xs:element>
377
+
378
+ <xs:element name="AuthenticatorTransportProtocol" type="AuthenticatorTransportProtocolType">
379
+ <xs:annotation>
380
+ <xs:documentation>
381
+ The protocol across which Authenticator information is
382
+ transferred to an Authentication Authority verifier.
383
+ </xs:documentation>
384
+ </xs:annotation>
385
+ </xs:element>
386
+
387
+ <xs:element name="HTTP" type="ExtensionOnlyType">
388
+ <xs:annotation>
389
+ <xs:documentation>
390
+ This element indicates that the Authenticator has been
391
+ transmitted using bare HTTP utilizing no additional security
392
+ protocols.
393
+ </xs:documentation>
394
+ </xs:annotation>
395
+ </xs:element>
396
+
397
+ <xs:element name="IPSec" type="ExtensionOnlyType">
398
+ <xs:annotation>
399
+ <xs:documentation>
400
+ This element indicates that the Authenticator has been
401
+ transmitted using a transport mechanism protected by an IPSEC session.
402
+ </xs:documentation>
403
+ </xs:annotation>
404
+ </xs:element>
405
+
406
+ <xs:element name="WTLS" type="ExtensionOnlyType">
407
+ <xs:annotation>
408
+ <xs:documentation>
409
+ This element indicates that the Authenticator has been
410
+ transmitted using a transport mechanism protected by a WTLS session.
411
+ </xs:documentation>
412
+ </xs:annotation>
413
+ </xs:element>
414
+
415
+ <xs:element name="MobileNetworkNoEncryption" type="ExtensionOnlyType">
416
+ <xs:annotation>
417
+ <xs:documentation>
418
+ This element indicates that the Authenticator has been
419
+ transmitted solely across a mobile network using no additional
420
+ security mechanism.
421
+ </xs:documentation>
422
+ </xs:annotation>
423
+ </xs:element>
424
+
425
+ <xs:element name="MobileNetworkRadioEncryption" type="ExtensionOnlyType"/>
426
+ <xs:element name="MobileNetworkEndToEndEncryption" type="ExtensionOnlyType"/>
427
+
428
+ <xs:element name="SSL" type="ExtensionOnlyType">
429
+ <xs:annotation>
430
+ <xs:documentation>
431
+ This element indicates that the Authenticator has been
432
+ transmitted using a transport mechnanism protected by an SSL or TLS
433
+ session.
434
+ </xs:documentation>
435
+ </xs:annotation>
436
+ </xs:element>
437
+
438
+ <xs:element name="PSTN" type="ExtensionOnlyType"/>
439
+ <xs:element name="ISDN" type="ExtensionOnlyType"/>
440
+ <xs:element name="ADSL" type="ExtensionOnlyType"/>
441
+
442
+ <xs:element name="OperationalProtection" type="OperationalProtectionType">
443
+ <xs:annotation>
444
+ <xs:documentation>
445
+ Refers to those characteristics that describe
446
+ procedural security controls employed by the Authentication Authority.
447
+ </xs:documentation>
448
+ </xs:annotation>
449
+ </xs:element>
450
+
451
+ <xs:element name="SecurityAudit" type="SecurityAuditType"/>
452
+ <xs:element name="SwitchAudit" type="ExtensionOnlyType"/>
453
+ <xs:element name="DeactivationCallCenter" type="ExtensionOnlyType"/>
454
+
455
+ <xs:element name="GoverningAgreements" type="GoverningAgreementsType">
456
+ <xs:annotation>
457
+ <xs:documentation>
458
+ Provides a mechanism for linking to external (likely
459
+ human readable) documents in which additional business agreements,
460
+ (e.g. liability constraints, obligations, etc) can be placed.
461
+ </xs:documentation>
462
+ </xs:annotation>
463
+ </xs:element>
464
+
465
+ <xs:element name="GoverningAgreementRef" type="GoverningAgreementRefType"/>
466
+
467
+ <xs:simpleType name="nymType">
468
+ <xs:restriction base="xs:NMTOKEN">
469
+ <xs:enumeration value="anonymity"/>
470
+ <xs:enumeration value="verinymity"/>
471
+ <xs:enumeration value="pseudonymity"/>
472
+ </xs:restriction>
473
+ </xs:simpleType>
474
+
475
+ <xs:complexType name="AuthnContextDeclarationBaseType">
476
+ <xs:sequence>
477
+ <xs:element ref="Identification" minOccurs="0"/>
478
+ <xs:element ref="TechnicalProtection" minOccurs="0"/>
479
+ <xs:element ref="OperationalProtection" minOccurs="0"/>
480
+ <xs:element ref="AuthnMethod" minOccurs="0"/>
481
+ <xs:element ref="GoverningAgreements" minOccurs="0"/>
482
+ <xs:element ref="Extension" minOccurs="0" maxOccurs="unbounded"/>
483
+ </xs:sequence>
484
+ <xs:attribute name="ID" type="xs:ID" use="optional"/>
485
+ </xs:complexType>
486
+
487
+ <xs:complexType name="IdentificationType">
488
+ <xs:sequence>
489
+ <xs:element ref="PhysicalVerification" minOccurs="0"/>
490
+ <xs:element ref="WrittenConsent" minOccurs="0"/>
491
+ <xs:element ref="GoverningAgreements" minOccurs="0"/>
492
+ <xs:element ref="Extension" minOccurs="0" maxOccurs="unbounded"/>
493
+ </xs:sequence>
494
+ <xs:attribute name="nym" type="nymType">
495
+ <xs:annotation>
496
+ <xs:documentation>
497
+ This attribute indicates whether or not the
498
+ Identification mechanisms allow the actions of the Principal to be
499
+ linked to an actual end user.
500
+ </xs:documentation>
501
+ </xs:annotation>
502
+ </xs:attribute>
503
+ </xs:complexType>
504
+
505
+ <xs:complexType name="TechnicalProtectionBaseType">
506
+ <xs:sequence>
507
+ <xs:choice minOccurs="0">
508
+ <xs:element ref="PrivateKeyProtection"/>
509
+ <xs:element ref="SecretKeyProtection"/>
510
+ </xs:choice>
511
+ <xs:element ref="Extension" minOccurs="0" maxOccurs="unbounded"/>
512
+ </xs:sequence>
513
+ </xs:complexType>
514
+
515
+ <xs:complexType name="OperationalProtectionType">
516
+ <xs:sequence>
517
+ <xs:element ref="SecurityAudit" minOccurs="0"/>
518
+ <xs:element ref="DeactivationCallCenter" minOccurs="0"/>
519
+ <xs:element ref="Extension" minOccurs="0" maxOccurs="unbounded"/>
520
+ </xs:sequence>
521
+ </xs:complexType>
522
+
523
+ <xs:complexType name="AuthnMethodBaseType">
524
+ <xs:sequence>
525
+ <xs:element ref="PrincipalAuthenticationMechanism" minOccurs="0"/>
526
+ <xs:element ref="Authenticator" minOccurs="0"/>
527
+ <xs:element ref="AuthenticatorTransportProtocol" minOccurs="0"/>
528
+ <xs:element ref="Extension" minOccurs="0" maxOccurs="unbounded"/>
529
+ </xs:sequence>
530
+ </xs:complexType>
531
+
532
+ <xs:complexType name="GoverningAgreementsType">
533
+ <xs:sequence>
534
+ <xs:element ref="GoverningAgreementRef" maxOccurs="unbounded"/>
535
+ </xs:sequence>
536
+ </xs:complexType>
537
+
538
+ <xs:complexType name="GoverningAgreementRefType">
539
+ <xs:attribute name="governingAgreementRef" type="xs:anyURI" use="required"/>
540
+ </xs:complexType>
541
+
542
+ <xs:complexType name="PrincipalAuthenticationMechanismType">
543
+ <xs:sequence>
544
+ <xs:element ref="Password" minOccurs="0"/>
545
+ <xs:element ref="RestrictedPassword" minOccurs="0"/>
546
+ <xs:element ref="Token" minOccurs="0"/>
547
+ <xs:element ref="Smartcard" minOccurs="0"/>
548
+ <xs:element ref="ActivationPin" minOccurs="0"/>
549
+ <xs:element ref="Extension" minOccurs="0" maxOccurs="unbounded"/>
550
+ </xs:sequence>
551
+ <xs:attribute name="preauth" type="xs:integer" use="optional"/>
552
+ </xs:complexType>
553
+
554
+ <xs:group name="AuthenticatorChoiceGroup">
555
+ <xs:choice>
556
+ <xs:element ref="PreviousSession"/>
557
+ <xs:element ref="ResumeSession"/>
558
+ <xs:element ref="DigSig"/>
559
+ <xs:element ref="Password"/>
560
+ <xs:element ref="RestrictedPassword"/>
561
+ <xs:element ref="ZeroKnowledge"/>
562
+ <xs:element ref="SharedSecretChallengeResponse"/>
563
+ <xs:element ref="SharedSecretDynamicPlaintext"/>
564
+ <xs:element ref="IPAddress"/>
565
+ <xs:element ref="AsymmetricDecryption"/>
566
+ <xs:element ref="AsymmetricKeyAgreement"/>
567
+ <xs:element ref="SubscriberLineNumber"/>
568
+ <xs:element ref="UserSuffix"/>
569
+ <xs:element ref="ComplexAuthenticator"/>
570
+ </xs:choice>
571
+ </xs:group>
572
+
573
+ <xs:group name="AuthenticatorSequenceGroup">
574
+ <xs:sequence>
575
+ <xs:element ref="PreviousSession" minOccurs="0"/>
576
+ <xs:element ref="ResumeSession" minOccurs="0"/>
577
+ <xs:element ref="DigSig" minOccurs="0"/>
578
+ <xs:element ref="Password" minOccurs="0"/>
579
+ <xs:element ref="RestrictedPassword" minOccurs="0"/>
580
+ <xs:element ref="ZeroKnowledge" minOccurs="0"/>
581
+ <xs:element ref="SharedSecretChallengeResponse" minOccurs="0"/>
582
+ <xs:element ref="SharedSecretDynamicPlaintext" minOccurs="0"/>
583
+ <xs:element ref="IPAddress" minOccurs="0"/>
584
+ <xs:element ref="AsymmetricDecryption" minOccurs="0"/>
585
+ <xs:element ref="AsymmetricKeyAgreement" minOccurs="0"/>
586
+ <xs:element ref="SubscriberLineNumber" minOccurs="0"/>
587
+ <xs:element ref="UserSuffix" minOccurs="0"/>
588
+ <xs:element ref="Extension" minOccurs="0" maxOccurs="unbounded"/>
589
+ </xs:sequence>
590
+ </xs:group>
591
+
592
+ <xs:complexType name="AuthenticatorBaseType">
593
+ <xs:sequence>
594
+ <xs:group ref="AuthenticatorChoiceGroup"/>
595
+ <xs:group ref="AuthenticatorSequenceGroup"/>
596
+ </xs:sequence>
597
+ </xs:complexType>
598
+
599
+ <xs:complexType name="ComplexAuthenticatorType">
600
+ <xs:sequence>
601
+ <xs:group ref="AuthenticatorChoiceGroup"/>
602
+ <xs:group ref="AuthenticatorSequenceGroup"/>
603
+ </xs:sequence>
604
+ </xs:complexType>
605
+
606
+ <xs:complexType name="AuthenticatorTransportProtocolType">
607
+ <xs:sequence>
608
+ <xs:choice minOccurs="0">
609
+ <xs:element ref="HTTP"/>
610
+ <xs:element ref="SSL"/>
611
+ <xs:element ref="MobileNetworkNoEncryption"/>
612
+ <xs:element ref="MobileNetworkRadioEncryption"/>
613
+ <xs:element ref="MobileNetworkEndToEndEncryption"/>
614
+ <xs:element ref="WTLS"/>
615
+ <xs:element ref="IPSec"/>
616
+ <xs:element ref="PSTN"/>
617
+ <xs:element ref="ISDN"/>
618
+ <xs:element ref="ADSL"/>
619
+ </xs:choice>
620
+ <xs:element ref="Extension" minOccurs="0" maxOccurs="unbounded"/>
621
+ </xs:sequence>
622
+ </xs:complexType>
623
+
624
+ <xs:complexType name="KeyActivationType">
625
+ <xs:sequence>
626
+ <xs:element ref="ActivationPin" minOccurs="0"/>
627
+ <xs:element ref="Extension" minOccurs="0" maxOccurs="unbounded"/>
628
+ </xs:sequence>
629
+ </xs:complexType>
630
+
631
+ <xs:complexType name="KeySharingType">
632
+ <xs:attribute name="sharing" type="xs:boolean" use="required"/>
633
+ </xs:complexType>
634
+
635
+ <xs:complexType name="PrivateKeyProtectionType">
636
+ <xs:sequence>
637
+ <xs:element ref="KeyActivation" minOccurs="0"/>
638
+ <xs:element ref="KeyStorage" minOccurs="0"/>
639
+ <xs:element ref="KeySharing" minOccurs="0"/>
640
+ <xs:element ref="Extension" minOccurs="0" maxOccurs="unbounded"/>
641
+ </xs:sequence>
642
+ </xs:complexType>
643
+
644
+ <xs:complexType name="PasswordType">
645
+ <xs:sequence>
646
+ <xs:element ref="Length" minOccurs="0"/>
647
+ <xs:element ref="Alphabet" minOccurs="0"/>
648
+ <xs:element ref="Generation" minOccurs="0"/>
649
+ <xs:element ref="Extension" minOccurs="0" maxOccurs="unbounded"/>
650
+ </xs:sequence>
651
+ <xs:attribute name="ExternalVerification" type="xs:anyURI" use="optional"/>
652
+ </xs:complexType>
653
+
654
+ <xs:element name="RestrictedPassword" type="RestrictedPasswordType"/>
655
+
656
+ <xs:complexType name="RestrictedPasswordType">
657
+ <xs:complexContent>
658
+ <xs:restriction base="PasswordType">
659
+ <xs:sequence>
660
+ <xs:element name="Length" type="RestrictedLengthType" minOccurs="1"/>
661
+ <xs:element ref="Generation" minOccurs="0"/>
662
+ <xs:element ref="Extension" minOccurs="0" maxOccurs="unbounded"/>
663
+ </xs:sequence>
664
+ <xs:attribute name="ExternalVerification" type="xs:anyURI" use="optional"/>
665
+ </xs:restriction>
666
+ </xs:complexContent>
667
+ </xs:complexType>
668
+
669
+ <xs:complexType name="RestrictedLengthType">
670
+ <xs:complexContent>
671
+ <xs:restriction base="LengthType">
672
+ <xs:attribute name="min" use="required">
673
+ <xs:simpleType>
674
+ <xs:restriction base="xs:integer">
675
+ <xs:minInclusive value="3"/>
676
+ </xs:restriction>
677
+ </xs:simpleType>
678
+ </xs:attribute>
679
+ <xs:attribute name="max" type="xs:integer" use="optional"/>
680
+ </xs:restriction>
681
+ </xs:complexContent>
682
+ </xs:complexType>
683
+
684
+ <xs:complexType name="ActivationPinType">
685
+ <xs:sequence>
686
+ <xs:element ref="Length" minOccurs="0"/>
687
+ <xs:element ref="Alphabet" minOccurs="0"/>
688
+ <xs:element ref="Generation" minOccurs="0"/>
689
+ <xs:element ref="ActivationLimit" minOccurs="0"/>
690
+ <xs:element ref="Extension" minOccurs="0" maxOccurs="unbounded"/>
691
+ </xs:sequence>
692
+ </xs:complexType>
693
+
694
+ <xs:element name="Alphabet" type="AlphabetType"/>
695
+ <xs:complexType name="AlphabetType">
696
+ <xs:attribute name="requiredChars" type="xs:string" use="required"/>
697
+ <xs:attribute name="excludedChars" type="xs:string" use="optional"/>
698
+ <xs:attribute name="case" type="xs:string" use="optional"/>
699
+ </xs:complexType>
700
+
701
+ <xs:complexType name="TokenType">
702
+ <xs:sequence>
703
+ <xs:element ref="TimeSyncToken"/>
704
+ <xs:element ref="Extension" minOccurs="0" maxOccurs="unbounded"/>
705
+ </xs:sequence>
706
+ </xs:complexType>
707
+
708
+ <xs:simpleType name="DeviceTypeType">
709
+ <xs:restriction base="xs:NMTOKEN">
710
+ <xs:enumeration value="hardware"/>
711
+ <xs:enumeration value="software"/>
712
+ </xs:restriction>
713
+ </xs:simpleType>
714
+
715
+ <xs:simpleType name="booleanType">
716
+ <xs:restriction base="xs:NMTOKEN">
717
+ <xs:enumeration value="true"/>
718
+ <xs:enumeration value="false"/>
719
+ </xs:restriction>
720
+ </xs:simpleType>
721
+
722
+ <xs:complexType name="TimeSyncTokenType">
723
+ <xs:attribute name="DeviceType" type="DeviceTypeType" use="required"/>
724
+ <xs:attribute name="SeedLength" type="xs:integer" use="required"/>
725
+ <xs:attribute name="DeviceInHand" type="booleanType" use="required"/>
726
+ </xs:complexType>
727
+
728
+ <xs:complexType name="ActivationLimitType">
729
+ <xs:choice>
730
+ <xs:element ref="ActivationLimitDuration"/>
731
+ <xs:element ref="ActivationLimitUsages"/>
732
+ <xs:element ref="ActivationLimitSession"/>
733
+ </xs:choice>
734
+ </xs:complexType>
735
+
736
+ <xs:element name="ActivationLimitDuration" type="ActivationLimitDurationType">
737
+ <xs:annotation>
738
+ <xs:documentation>
739
+ This element indicates that the Key Activation Limit is
740
+ defined as a specific duration of time.
741
+ </xs:documentation>
742
+ </xs:annotation>
743
+ </xs:element>
744
+
745
+ <xs:element name="ActivationLimitUsages" type="ActivationLimitUsagesType">
746
+ <xs:annotation>
747
+ <xs:documentation>
748
+ This element indicates that the Key Activation Limit is
749
+ defined as a number of usages.
750
+ </xs:documentation>
751
+ </xs:annotation>
752
+ </xs:element>
753
+
754
+ <xs:element name="ActivationLimitSession" type="ActivationLimitSessionType">
755
+ <xs:annotation>
756
+ <xs:documentation>
757
+ This element indicates that the Key Activation Limit is
758
+ the session.
759
+ </xs:documentation>
760
+ </xs:annotation>
761
+ </xs:element>
762
+
763
+ <xs:complexType name="ActivationLimitDurationType">
764
+ <xs:attribute name="duration" type="xs:duration" use="required"/>
765
+ </xs:complexType>
766
+
767
+ <xs:complexType name="ActivationLimitUsagesType">
768
+ <xs:attribute name="number" type="xs:integer" use="required"/>
769
+ </xs:complexType>
770
+
771
+ <xs:complexType name="ActivationLimitSessionType"/>
772
+
773
+ <xs:complexType name="LengthType">
774
+ <xs:attribute name="min" type="xs:integer" use="required"/>
775
+ <xs:attribute name="max" type="xs:integer" use="optional"/>
776
+ </xs:complexType>
777
+
778
+ <xs:simpleType name="mediumType">
779
+ <xs:restriction base="xs:NMTOKEN">
780
+ <xs:enumeration value="memory"/>
781
+ <xs:enumeration value="smartcard"/>
782
+ <xs:enumeration value="token"/>
783
+ <xs:enumeration value="MobileDevice"/>
784
+ <xs:enumeration value="MobileAuthCard"/>
785
+ </xs:restriction>
786
+ </xs:simpleType>
787
+
788
+ <xs:complexType name="KeyStorageType">
789
+ <xs:attribute name="medium" type="mediumType" use="required"/>
790
+ </xs:complexType>
791
+
792
+ <xs:complexType name="SecretKeyProtectionType">
793
+ <xs:sequence>
794
+ <xs:element ref="KeyActivation" minOccurs="0"/>
795
+ <xs:element ref="KeyStorage" minOccurs="0"/>
796
+ <xs:element ref="Extension" minOccurs="0" maxOccurs="unbounded"/>
797
+ </xs:sequence>
798
+ </xs:complexType>
799
+
800
+ <xs:complexType name="SecurityAuditType">
801
+ <xs:sequence>
802
+ <xs:element ref="SwitchAudit" minOccurs="0"/>
803
+ <xs:element ref="Extension" minOccurs="0" maxOccurs="unbounded"/>
804
+ </xs:sequence>
805
+ </xs:complexType>
806
+
807
+ <xs:complexType name="ExtensionOnlyType">
808
+ <xs:sequence>
809
+ <xs:element ref="Extension" minOccurs="0" maxOccurs="unbounded"/>
810
+ </xs:sequence>
811
+ </xs:complexType>
812
+
813
+ <xs:element name="Extension" type="ExtensionType"/>
814
+
815
+ <xs:complexType name="ExtensionType">
816
+ <xs:sequence>
817
+ <xs:any namespace="##other" processContents="lax" maxOccurs="unbounded"/>
818
+ </xs:sequence>
819
+ </xs:complexType>
820
+
821
+ </xs:schema>