Chromium Code Reviews
chromiumcodereview-hr@appspot.gserviceaccount.com (chromiumcodereview-hr) | Please choose your nickname with Settings | Help | Chromium Project | Gerrit Changes | Sign out
(1)

Side by Side Diff: third_party/google-endpoints/pyasn1_modules/rfc2459.py

Issue 2666783008: Add google-endpoints to third_party/. (Closed)
Patch Set: Created 3 years, 10 months ago
Use n/p to move between diff chunks; N/P to move between comments. Draft comments are only viewable by you.
Jump to:
View unified diff | Download patch
OLDNEW
(Empty)
1 #
2 # X.509 message syntax
3 #
4 # ASN.1 source from:
5 # http://www.trl.ibm.com/projects/xml/xss4j/data/asn1/grammars/x509.asn
6 # http://www.ietf.org/rfc/rfc2459.txt
7 #
8 # Sample captures from:
9 # http://wiki.wireshark.org/SampleCaptures/
10 #
11 from pyasn1.type import tag,namedtype,namedval,univ,constraint,char,useful
12
13 MAX = 64 # XXX ?
14
15 #
16 # PKIX1Explicit88
17 #
18
19 # Upper Bounds
20 ub_name = univ.Integer(32768)
21 ub_common_name = univ.Integer(64)
22 ub_locality_name = univ.Integer(128)
23 ub_state_name = univ.Integer(128)
24 ub_organization_name = univ.Integer(64)
25 ub_organizational_unit_name = univ.Integer(64)
26 ub_title = univ.Integer(64)
27 ub_match = univ.Integer(128)
28 ub_emailaddress_length = univ.Integer(128)
29 ub_common_name_length = univ.Integer(64)
30 ub_country_name_alpha_length = univ.Integer(2)
31 ub_country_name_numeric_length = univ.Integer(3)
32 ub_domain_defined_attributes = univ.Integer(4)
33 ub_domain_defined_attribute_type_length = univ.Integer(8)
34 ub_domain_defined_attribute_value_length = univ.Integer(128)
35 ub_domain_name_length = univ.Integer(16)
36 ub_extension_attributes = univ.Integer(256)
37 ub_e163_4_number_length = univ.Integer(15)
38 ub_e163_4_sub_address_length = univ.Integer(40)
39 ub_generation_qualifier_length = univ.Integer(3)
40 ub_given_name_length = univ.Integer(16)
41 ub_initials_length = univ.Integer(5)
42 ub_integer_options = univ.Integer(256)
43 ub_numeric_user_id_length = univ.Integer(32)
44 ub_organization_name_length = univ.Integer(64)
45 ub_organizational_unit_name_length = univ.Integer(32)
46 ub_organizational_units = univ.Integer(4)
47 ub_pds_name_length = univ.Integer(16)
48 ub_pds_parameter_length = univ.Integer(30)
49 ub_pds_physical_address_lines = univ.Integer(6)
50 ub_postal_code_length = univ.Integer(16)
51 ub_surname_length = univ.Integer(40)
52 ub_terminal_id_length = univ.Integer(24)
53 ub_unformatted_address_length = univ.Integer(180)
54 ub_x121_address_length = univ.Integer(16)
55
56 class UniversalString(char.UniversalString): pass
57 class BMPString(char.BMPString): pass
58 class UTF8String(char.UTF8String): pass
59
60 id_pkix = univ.ObjectIdentifier('1.3.6.1.5.5.7')
61 id_pe = univ.ObjectIdentifier('1.3.6.1.5.5.7.1')
62 id_qt = univ.ObjectIdentifier('1.3.6.1.5.5.7.2')
63 id_kp = univ.ObjectIdentifier('1.3.6.1.5.5.7.3')
64 id_ad = univ.ObjectIdentifier('1.3.6.1.5.5.7.48')
65
66 id_qt_cps = univ.ObjectIdentifier('1.3.6.1.5.5.7.2.1')
67 id_qt_unotice = univ.ObjectIdentifier('1.3.6.1.5.5.7.2.2')
68
69 id_ad_ocsp = univ.ObjectIdentifier('1.3.6.1.5.5.7.48.1')
70 id_ad_caIssuers = univ.ObjectIdentifier('1.3.6.1.5.5.7.48.2')
71
72 class AttributeValue(univ.Any): pass
73
74 class AttributeType(univ.ObjectIdentifier): pass
75
76 class AttributeTypeAndValue(univ.Sequence):
77 componentType = namedtype.NamedTypes(
78 namedtype.NamedType('type', AttributeType()),
79 namedtype.NamedType('value', AttributeValue())
80 )
81
82 class Attribute(univ.Sequence):
83 componentType = namedtype.NamedTypes(
84 namedtype.NamedType('type', AttributeType()),
85 namedtype.NamedType('vals', univ.SetOf(componentType=AttributeValue()))
86 )
87
88 id_at = univ.ObjectIdentifier('2.5.4')
89 id_at_name = univ.ObjectIdentifier('2.5.4.41')
90 # preserve misspelled variable for compatibility
91 id_at_sutname = id_at_surname = univ.ObjectIdentifier('2.5.4.4')
92 id_at_givenName = univ.ObjectIdentifier('2.5.4.42')
93 id_at_initials = univ.ObjectIdentifier('2.5.4.43')
94 id_at_generationQualifier = univ.ObjectIdentifier('2.5.4.44')
95
96 class X520name(univ.Choice):
97 componentType = namedtype.NamedTypes(
98 namedtype.NamedType('teletexString', char.TeletexString().subtype(subtyp eSpec=constraint.ValueSizeConstraint(1, ub_name))),
99 namedtype.NamedType('printableString', char.PrintableString().subtype(su btypeSpec=constraint.ValueSizeConstraint(1, ub_name))),
100 namedtype.NamedType('universalString', char.UniversalString().subtype(su btypeSpec=constraint.ValueSizeConstraint(1, ub_name))),
101 namedtype.NamedType('utf8String', char.UTF8String().subtype(subtypeSpec= constraint.ValueSizeConstraint(1, ub_name))),
102 namedtype.NamedType('bmpString', char.BMPString().subtype(subtypeSpec=co nstraint.ValueSizeConstraint(1, ub_name)))
103 )
104
105 id_at_commonName = univ.ObjectIdentifier('2.5.4.3')
106
107 class X520CommonName(univ.Choice):
108 componentType = namedtype.NamedTypes(
109 namedtype.NamedType('teletexString', char.TeletexString().subtype(subtyp eSpec=constraint.ValueSizeConstraint(1, ub_common_name))),
110 namedtype.NamedType('printableString', char.PrintableString().subtype(su btypeSpec=constraint.ValueSizeConstraint(1, ub_common_name))),
111 namedtype.NamedType('universalString', char.UniversalString().subtype(su btypeSpec=constraint.ValueSizeConstraint(1, ub_common_name))),
112 namedtype.NamedType('utf8String', char.UTF8String().subtype(subtypeSpec= constraint.ValueSizeConstraint(1, ub_common_name))),
113 namedtype.NamedType('bmpString', char.BMPString().subtype(subtypeSpec=co nstraint.ValueSizeConstraint(1, ub_common_name)))
114 )
115
116 id_at_localityName = univ.ObjectIdentifier('2.5.4.7')
117
118 class X520LocalityName(univ.Choice):
119 componentType = namedtype.NamedTypes(
120 namedtype.NamedType('teletexString', char.TeletexString().subtype(subtyp eSpec=constraint.ValueSizeConstraint(1, ub_locality_name))),
121 namedtype.NamedType('printableString', char.PrintableString().subtype(su btypeSpec=constraint.ValueSizeConstraint(1, ub_locality_name))),
122 namedtype.NamedType('universalString', char.UniversalString().subtype(su btypeSpec=constraint.ValueSizeConstraint(1, ub_locality_name))),
123 namedtype.NamedType('utf8String', char.UTF8String().subtype(subtypeSpec= constraint.ValueSizeConstraint(1, ub_locality_name))),
124 namedtype.NamedType('bmpString', char.BMPString().subtype(subtypeSpec=co nstraint.ValueSizeConstraint(1, ub_locality_name)))
125 )
126
127 id_at_stateOrProvinceName = univ.ObjectIdentifier('2.5.4.8')
128
129 class X520StateOrProvinceName(univ.Choice):
130 componentType = namedtype.NamedTypes(
131 namedtype.NamedType('teletexString', char.TeletexString().subtype(subtyp eSpec=constraint.ValueSizeConstraint(1, ub_state_name))),
132 namedtype.NamedType('printableString', char.PrintableString().subtype(su btypeSpec=constraint.ValueSizeConstraint(1, ub_state_name))),
133 namedtype.NamedType('universalString', char.UniversalString().subtype(su btypeSpec=constraint.ValueSizeConstraint(1, ub_state_name))),
134 namedtype.NamedType('utf8String', char.UTF8String().subtype(subtypeSpec= constraint.ValueSizeConstraint(1, ub_state_name))),
135 namedtype.NamedType('bmpString', char.BMPString().subtype(subtypeSpec=co nstraint.ValueSizeConstraint(1, ub_state_name)))
136 )
137
138 id_at_organizationName = univ.ObjectIdentifier('2.5.4.10')
139
140 class X520OrganizationName(univ.Choice):
141 componentType = namedtype.NamedTypes(
142 namedtype.NamedType('teletexString', char.TeletexString().subtype(subtyp eSpec=constraint.ValueSizeConstraint(1, ub_organization_name))),
143 namedtype.NamedType('printableString', char.PrintableString().subtype(su btypeSpec=constraint.ValueSizeConstraint(1, ub_organization_name))),
144 namedtype.NamedType('universalString', char.UniversalString().subtype(su btypeSpec=constraint.ValueSizeConstraint(1, ub_organization_name))),
145 namedtype.NamedType('utf8String', char.UTF8String().subtype(subtypeSpec= constraint.ValueSizeConstraint(1, ub_organization_name))),
146 namedtype.NamedType('bmpString', char.BMPString().subtype(subtypeSpec=co nstraint.ValueSizeConstraint(1, ub_organization_name)))
147 )
148
149 id_at_organizationalUnitName = univ.ObjectIdentifier('2.5.4.11')
150
151 class X520OrganizationalUnitName(univ.Choice):
152 componentType = namedtype.NamedTypes(
153 namedtype.NamedType('teletexString', char.TeletexString().subtype(subtyp eSpec=constraint.ValueSizeConstraint(1, ub_organizational_unit_name))),
154 namedtype.NamedType('printableString', char.PrintableString().subtype(su btypeSpec=constraint.ValueSizeConstraint(1, ub_organizational_unit_name))),
155 namedtype.NamedType('universalString', char.UniversalString().subtype(su btypeSpec=constraint.ValueSizeConstraint(1, ub_organizational_unit_name))),
156 namedtype.NamedType('utf8String', char.UTF8String().subtype(subtypeSpec= constraint.ValueSizeConstraint(1, ub_organizational_unit_name))),
157 namedtype.NamedType('bmpString', char.BMPString().subtype(subtypeSpec=co nstraint.ValueSizeConstraint(1, ub_organizational_unit_name)))
158 )
159
160 id_at_title = univ.ObjectIdentifier('2.5.4.12')
161
162 class X520Title(univ.Choice):
163 componentType = namedtype.NamedTypes(
164 namedtype.NamedType('teletexString', char.TeletexString().subtype(subtyp eSpec=constraint.ValueSizeConstraint(1, ub_title))),
165 namedtype.NamedType('printableString', char.PrintableString().subtype(su btypeSpec=constraint.ValueSizeConstraint(1, ub_title))),
166 namedtype.NamedType('universalString', char.UniversalString().subtype(su btypeSpec=constraint.ValueSizeConstraint(1, ub_title))),
167 namedtype.NamedType('utf8String', char.UTF8String().subtype(subtypeSpec= constraint.ValueSizeConstraint(1, ub_title))),
168 namedtype.NamedType('bmpString', char.BMPString().subtype(subtypeSpec=co nstraint.ValueSizeConstraint(1, ub_title)))
169 )
170
171 id_at_dnQualifier = univ.ObjectIdentifier('2.5.4.46')
172
173 class X520dnQualifier(char.PrintableString): pass
174
175 id_at_countryName = univ.ObjectIdentifier('2.5.4.6')
176
177 class X520countryName(char.PrintableString):
178 subtypeSpec = char.PrintableString.subtypeSpec + constraint.ValueSizeConstra int(2, 2)
179
180 pkcs_9 = univ.ObjectIdentifier('1.2.840.113549.1.9')
181
182 emailAddress = univ.ObjectIdentifier('1.2.840.113549.1.9.1')
183
184 class Pkcs9email(char.IA5String):
185 subtypeSpec = char.IA5String.subtypeSpec + constraint.ValueSizeConstraint(1, ub_emailaddress_length)
186
187 # ----
188
189 class DSAPrivateKey(univ.Sequence):
190 """PKIX compliant DSA private key structure"""
191 componentType = namedtype.NamedTypes(
192 namedtype.NamedType('version', univ.Integer(namedValues=namedval.NamedVa lues(('v1', 0)))),
193 namedtype.NamedType('p', univ.Integer()),
194 namedtype.NamedType('q', univ.Integer()),
195 namedtype.NamedType('g', univ.Integer()),
196 namedtype.NamedType('public', univ.Integer()),
197 namedtype.NamedType('private', univ.Integer())
198 )
199
200 # ----
201
202 class RelativeDistinguishedName(univ.SetOf):
203 componentType = AttributeTypeAndValue()
204
205 class RDNSequence(univ.SequenceOf):
206 componentType = RelativeDistinguishedName()
207
208 class Name(univ.Choice):
209 componentType = namedtype.NamedTypes(
210 namedtype.NamedType('', RDNSequence())
211 )
212
213 class DirectoryString(univ.Choice):
214 componentType = namedtype.NamedTypes(
215 namedtype.NamedType('teletexString', char.TeletexString().subtype(subtyp eSpec=constraint.ValueSizeConstraint(1, MAX))),
216 namedtype.NamedType('printableString', char.PrintableString().subtype(su btypeSpec=constraint.ValueSizeConstraint(1, MAX))),
217 namedtype.NamedType('universalString', char.UniversalString().subtype(su btypeSpec=constraint.ValueSizeConstraint(1, MAX))),
218 namedtype.NamedType('utf8String', char.UTF8String().subtype(subtypeSpec= constraint.ValueSizeConstraint(1, MAX))),
219 namedtype.NamedType('bmpString', char.BMPString().subtype(subtypeSpec=co nstraint.ValueSizeConstraint(1, MAX))),
220 namedtype.NamedType('ia5String', char.IA5String().subtype(subtypeSpec=co nstraint.ValueSizeConstraint(1, MAX))) # hm, this should not be here!? XXX
221 )
222
223 # certificate and CRL specific structures begin here
224
225 class AlgorithmIdentifier(univ.Sequence):
226 componentType = namedtype.NamedTypes(
227 namedtype.NamedType('algorithm', univ.ObjectIdentifier()),
228 namedtype.OptionalNamedType('parameters', univ.Any())
229 )
230
231 class Extension(univ.Sequence):
232 componentType = namedtype.NamedTypes(
233 namedtype.NamedType('extnID', univ.ObjectIdentifier()),
234 namedtype.DefaultedNamedType('critical', univ.Boolean('False')),
235 namedtype.NamedType('extnValue', univ.Any())
236 )
237
238 class Extensions(univ.SequenceOf):
239 componentType = Extension()
240 sizeSpec = univ.SequenceOf.sizeSpec + constraint.ValueSizeConstraint(1, MAX)
241
242 class SubjectPublicKeyInfo(univ.Sequence):
243 componentType = namedtype.NamedTypes(
244 namedtype.NamedType('algorithm', AlgorithmIdentifier()),
245 namedtype.NamedType('subjectPublicKey', univ.BitString())
246 )
247
248 class UniqueIdentifier(univ.BitString): pass
249
250 class Time(univ.Choice):
251 componentType = namedtype.NamedTypes(
252 namedtype.NamedType('utcTime', useful.UTCTime()),
253 namedtype.NamedType('generalTime', useful.GeneralizedTime())
254 )
255
256 class Validity(univ.Sequence):
257 componentType = namedtype.NamedTypes(
258 namedtype.NamedType('notBefore', Time()),
259 namedtype.NamedType('notAfter', Time())
260 )
261
262 class CertificateSerialNumber(univ.Integer): pass
263
264 class Version(univ.Integer):
265 namedValues = namedval.NamedValues(
266 ('v1', 0), ('v2', 1), ('v3', 2)
267 )
268
269 class TBSCertificate(univ.Sequence):
270 componentType = namedtype.NamedTypes(
271 namedtype.DefaultedNamedType('version', Version('v1').subtype(explicitTa g=tag.Tag(tag.tagClassContext, tag.tagFormatSimple, 0))),
272 namedtype.NamedType('serialNumber', CertificateSerialNumber()),
273 namedtype.NamedType('signature', AlgorithmIdentifier()),
274 namedtype.NamedType('issuer', Name()),
275 namedtype.NamedType('validity', Validity()),
276 namedtype.NamedType('subject', Name()),
277 namedtype.NamedType('subjectPublicKeyInfo', SubjectPublicKeyInfo()),
278 namedtype.OptionalNamedType('issuerUniqueID', UniqueIdentifier().subtype (implicitTag=tag.Tag(tag.tagClassContext, tag.tagFormatSimple, 1))),
279 namedtype.OptionalNamedType('subjectUniqueID', UniqueIdentifier().subtyp e(implicitTag=tag.Tag(tag.tagClassContext, tag.tagFormatSimple, 2))),
280 namedtype.OptionalNamedType('extensions', Extensions().subtype(explicitT ag=tag.Tag(tag.tagClassContext, tag.tagFormatSimple, 3)))
281 )
282
283 class Certificate(univ.Sequence):
284 componentType = namedtype.NamedTypes(
285 namedtype.NamedType('tbsCertificate', TBSCertificate()),
286 namedtype.NamedType('signatureAlgorithm', AlgorithmIdentifier()),
287 namedtype.NamedType('signatureValue', univ.BitString())
288 )
289
290 # CRL structures
291
292 class RevokedCertificate(univ.Sequence):
293 componentType = namedtype.NamedTypes(
294 namedtype.NamedType('userCertificate', CertificateSerialNumber()),
295 namedtype.NamedType('revocationDate', Time()),
296 namedtype.OptionalNamedType('crlEntryExtensions', Extensions())
297 )
298
299 class TBSCertList(univ.Sequence):
300 componentType = namedtype.NamedTypes(
301 namedtype.OptionalNamedType('version', Version()),
302 namedtype.NamedType('signature', AlgorithmIdentifier()),
303 namedtype.NamedType('issuer', Name()),
304 namedtype.NamedType('thisUpdate', Time()),
305 namedtype.OptionalNamedType('nextUpdate', Time()),
306 namedtype.OptionalNamedType('revokedCertificates', univ.SequenceOf(compo nentType=RevokedCertificate())),
307 namedtype.OptionalNamedType('crlExtensions', Extensions().subtype(explic itTag=tag.Tag(tag.tagClassContext, tag.tagFormatConstructed, 0)))
308 )
309
310 class CertificateList(univ.Sequence):
311 componentType = namedtype.NamedTypes(
312 namedtype.NamedType('tbsCertList', TBSCertList()),
313 namedtype.NamedType('signatureAlgorithm', AlgorithmIdentifier()),
314 namedtype.NamedType('signature', univ.BitString())
315 )
316
317 # Algorithm OIDs and parameter structures
318
319 pkcs_1 = univ.ObjectIdentifier('1.2.840.113549.1.1')
320 rsaEncryption = univ.ObjectIdentifier('1.2.840.113549.1.1.1')
321 md2WithRSAEncryption = univ.ObjectIdentifier('1.2.840.113549.1.1.2')
322 md5WithRSAEncryption = univ.ObjectIdentifier('1.2.840.113549.1.1.4')
323 sha1WithRSAEncryption = univ.ObjectIdentifier('1.2.840.113549.1.1.5')
324 id_dsa_with_sha1 = univ.ObjectIdentifier('1.2.840.10040.4.3')
325
326 class Dss_Sig_Value(univ.Sequence):
327 componentType = namedtype.NamedTypes(
328 namedtype.NamedType('r', univ.Integer()),
329 namedtype.NamedType('s', univ.Integer())
330 )
331
332 dhpublicnumber = univ.ObjectIdentifier('1.2.840.10046.2.1')
333
334 class ValidationParms(univ.Sequence):
335 componentType = namedtype.NamedTypes(
336 namedtype.NamedType('seed', univ.BitString()),
337 namedtype.NamedType('pgenCounter', univ.Integer())
338 )
339
340 class DomainParameters(univ.Sequence):
341 componentType = namedtype.NamedTypes(
342 namedtype.NamedType('p', univ.Integer()),
343 namedtype.NamedType('g', univ.Integer()),
344 namedtype.NamedType('q', univ.Integer()),
345 namedtype.NamedType('j', univ.Integer()),
346 namedtype.OptionalNamedType('validationParms', ValidationParms())
347 )
348
349 id_dsa = univ.ObjectIdentifier('1.2.840.10040.4.1')
350
351 class Dss_Parms(univ.Sequence):
352 componentType = namedtype.NamedTypes(
353 namedtype.NamedType('p', univ.Integer()),
354 namedtype.NamedType('q', univ.Integer()),
355 namedtype.NamedType('g', univ.Integer())
356 )
357
358 # x400 address syntax starts here
359
360 teletex_domain_defined_attributes = univ.Integer(6)
361
362 class TeletexDomainDefinedAttribute(univ.Sequence):
363 componentType = namedtype.NamedTypes(
364 namedtype.NamedType('type', char.TeletexString().subtype(subtypeSpec=con straint.ValueSizeConstraint(1, ub_domain_defined_attribute_type_length))),
365 namedtype.NamedType('value', char.TeletexString())
366 )
367
368 class TeletexDomainDefinedAttributes(univ.SequenceOf):
369 componentType = TeletexDomainDefinedAttribute()
370 subtypeSpec = univ.SequenceOf.subtypeSpec + constraint.ValueSizeConstraint(1 , ub_domain_defined_attributes)
371
372 terminal_type = univ.Integer(23)
373
374 class TerminalType(univ.Integer):
375 subtypeSpec = univ.Integer.subtypeSpec + constraint.ValueSizeConstraint(0, u b_integer_options)
376 namedValues = namedval.NamedValues(
377 ('telex', 3),
378 ('teletelex', 4),
379 ('g3-facsimile', 5),
380 ('g4-facsimile', 6),
381 ('ia5-terminal', 7),
382 ('videotex', 8)
383 )
384
385 class PresentationAddress(univ.Sequence):
386 componentType = namedtype.NamedTypes(
387 namedtype.OptionalNamedType('pSelector', univ.OctetString().subtype(expl icitTag=tag.Tag(tag.tagClassContext, tag.tagFormatSimple, 0))),
388 namedtype.OptionalNamedType('sSelector', univ.OctetString().subtype(expl icitTag=tag.Tag(tag.tagClassContext, tag.tagFormatSimple, 1))),
389 namedtype.OptionalNamedType('tSelector', univ.OctetString().subtype(expl icitTag=tag.Tag(tag.tagClassContext, tag.tagFormatSimple, 2))),
390 namedtype.OptionalNamedType('nAddresses', univ.SetOf(componentType=univ. OctetString()).subtype(explicitTag=tag.Tag(tag.tagClassContext, tag.tagFormatSim ple, 3), subtypeSpec=constraint.ValueSizeConstraint(1, MAX))),
391 )
392
393 extended_network_address = univ.Integer(22)
394
395 class E163_4_address(univ.Sequence):
396 componentType = namedtype.NamedTypes(
397 namedtype.NamedType('number', char.NumericString().subtype(subtypeSpec=c onstraint.ValueSizeConstraint(1, ub_e163_4_number_length), explicitTag=tag.Tag(t ag.tagClassContext, tag.tagFormatSimple, 0))),
398 namedtype.OptionalNamedType('sub-address', char.NumericString().subtype( subtypeSpec=constraint.ValueSizeConstraint(1, ub_e163_4_sub_address_length), exp licitTag=tag.Tag(tag.tagClassContext, tag.tagFormatSimple, 1)))
399 )
400
401 class ExtendedNetworkAddress(univ.Choice):
402 componentType = namedtype.NamedTypes(
403 namedtype.NamedType('e163-4-address', E163_4_address()),
404 namedtype.NamedType('psap-address', PresentationAddress().subtype(explic itTag=tag.Tag(tag.tagClassContext, tag.tagFormatSimple, 0)))
405 )
406
407 class PDSParameter(univ.Set):
408 componentType = namedtype.NamedTypes(
409 namedtype.OptionalNamedType('printable-string', char.PrintableString().s ubtype(subtypeSpec=constraint.ValueSizeConstraint(1, ub_pds_parameter_length))),
410 namedtype.OptionalNamedType('teletex-string', char.TeletexString().subty pe(subtypeSpec=constraint.ValueSizeConstraint(1, ub_pds_parameter_length)))
411 )
412
413 local_postal_attributes = univ.Integer(21)
414
415 class LocalPostalAttributes(PDSParameter): pass
416
417 class UniquePostalName(PDSParameter): pass
418
419 unique_postal_name = univ.Integer(20)
420
421 poste_restante_address = univ.Integer(19)
422
423 class PosteRestanteAddress(PDSParameter): pass
424
425 post_office_box_address = univ.Integer(18)
426
427 class PostOfficeBoxAddress(PDSParameter): pass
428
429 street_address = univ.Integer(17)
430
431 class StreetAddress(PDSParameter): pass
432
433 class UnformattedPostalAddress(univ.Set):
434 componentType = namedtype.NamedTypes(
435 namedtype.OptionalNamedType('printable-address', univ.SequenceOf(compone ntType=char.PrintableString().subtype(subtypeSpec=constraint.ValueSizeConstraint (1, ub_pds_parameter_length)).subtype(subtypeSpec=constraint.ValueSizeConstraint (1, ub_pds_physical_address_lines)))),
436 namedtype.OptionalNamedType('teletex-string', char.TeletexString().subty pe(subtypeSpec=constraint.ValueSizeConstraint(1, ub_unformatted_address_length)) )
437 )
438
439 physical_delivery_office_name = univ.Integer(10)
440
441 class PhysicalDeliveryOfficeName(PDSParameter): pass
442
443 physical_delivery_office_number = univ.Integer(11)
444
445 class PhysicalDeliveryOfficeNumber(PDSParameter): pass
446
447 extension_OR_address_components = univ.Integer(12)
448
449 class ExtensionORAddressComponents(PDSParameter): pass
450
451 physical_delivery_personal_name = univ.Integer(13)
452
453 class PhysicalDeliveryPersonalName(PDSParameter): pass
454
455 physical_delivery_organization_name = univ.Integer(14)
456
457 class PhysicalDeliveryOrganizationName(PDSParameter): pass
458
459 extension_physical_delivery_address_components = univ.Integer(15)
460
461 class ExtensionPhysicalDeliveryAddressComponents(PDSParameter): pass
462
463 unformatted_postal_address = univ.Integer(16)
464
465 postal_code = univ.Integer(9)
466
467 class PostalCode(univ.Choice):
468 componentType = namedtype.NamedTypes(
469 namedtype.NamedType('numeric-code', char.NumericString().subtype(subtype Spec=constraint.ValueSizeConstraint(1, ub_postal_code_length))),
470 namedtype.NamedType('printable-code', char.PrintableString().subtype(sub typeSpec=constraint.ValueSizeConstraint(1, ub_postal_code_length)))
471 )
472
473 class PhysicalDeliveryCountryName(univ.Choice):
474 componentType = namedtype.NamedTypes(
475 namedtype.NamedType('x121-dcc-code', char.NumericString().subtype(subtyp eSpec=constraint.ValueSizeConstraint(ub_country_name_numeric_length, ub_country_ name_numeric_length))),
476 namedtype.NamedType('iso-3166-alpha2-code', char.PrintableString().subty pe(subtypeSpec=constraint.ValueSizeConstraint(ub_country_name_alpha_length, ub_c ountry_name_alpha_length)))
477 )
478
479 class PDSName(char.PrintableString):
480 subtypeSpec = char.PrintableString.subtypeSpec + constraint.ValueSizeConstra int(1, ub_pds_name_length)
481
482 physical_delivery_country_name = univ.Integer(8)
483
484 class TeletexOrganizationalUnitName(char.TeletexString):
485 subtypeSpec = char.TeletexString.subtypeSpec + constraint.ValueSizeConstrain t(1, ub_organizational_unit_name_length)
486
487 pds_name = univ.Integer(7)
488
489 teletex_organizational_unit_names = univ.Integer(5)
490
491 class TeletexOrganizationalUnitNames(univ.SequenceOf):
492 componentType = TeletexOrganizationalUnitName()
493 subtypeSpec = univ.SequenceOf.subtypeSpec + constraint.ValueSizeConstraint(1 , ub_organizational_units)
494
495 teletex_personal_name = univ.Integer(4)
496
497 class TeletexPersonalName(univ.Set):
498 componentType = namedtype.NamedTypes(
499 namedtype.NamedType('surname', char.TeletexString().subtype(subtypeSpec= constraint.ValueSizeConstraint(1, ub_surname_length), explicitTag=tag.Tag(tag.ta gClassContext, tag.tagFormatSimple, 0))),
500 namedtype.OptionalNamedType('given-name', char.TeletexString().subtype(s ubtypeSpec=constraint.ValueSizeConstraint(1, ub_given_name_length), explicitTag= tag.Tag(tag.tagClassContext, tag.tagFormatSimple, 1))),
501 namedtype.OptionalNamedType('initials', char.TeletexString().subtype(sub typeSpec=constraint.ValueSizeConstraint(1, ub_initials_length), explicitTag=tag. Tag(tag.tagClassContext, tag.tagFormatSimple, 2))),
502 namedtype.OptionalNamedType('generation-qualifier', char.TeletexString() .subtype(subtypeSpec=constraint.ValueSizeConstraint(1, ub_generation_qualifier_l ength), explicitTag=tag.Tag(tag.tagClassContext, tag.tagFormatSimple, 3)))
503 )
504
505 teletex_organization_name = univ.Integer(3)
506
507 class TeletexOrganizationName(char.TeletexString):
508 subtypeSpec = char.TeletexString.subtypeSpec + constraint.ValueSizeConstrain t(1, ub_organization_name_length)
509
510 teletex_common_name = univ.Integer(2)
511
512 class TeletexCommonName(char.TeletexString):
513 subtypeSpec = char.TeletexString.subtypeSpec + constraint.ValueSizeConstrain t(1, ub_common_name_length)
514
515 class CommonName(char.PrintableString):
516 subtypeSpec = char.PrintableString.subtypeSpec + constraint.ValueSizeConstra int(1, ub_common_name_length)
517
518 common_name = univ.Integer(1)
519
520 class ExtensionAttribute(univ.Sequence):
521 componentType = namedtype.NamedTypes(
522 namedtype.NamedType('extension-attribute-type', univ.Integer().subtype(s ubtypeSpec=constraint.ValueSizeConstraint(0, ub_extension_attributes), explicitT ag=tag.Tag(tag.tagClassContext, tag.tagFormatSimple, 0))),
523 namedtype.NamedType('extension-attribute-value', univ.Any().subtype(expl icitTag=tag.Tag(tag.tagClassContext, tag.tagFormatSimple, 1)))
524 )
525
526 class ExtensionAttributes(univ.SetOf):
527 componentType = ExtensionAttribute()
528 subtypeSpec = univ.SetOf.subtypeSpec + constraint.ValueSizeConstraint(1, ub_ extension_attributes)
529
530 class BuiltInDomainDefinedAttribute(univ.Sequence):
531 componentType = namedtype.NamedTypes(
532 namedtype.NamedType('type', char.PrintableString().subtype(subtypeSpec=c onstraint.ValueSizeConstraint(1, ub_domain_defined_attribute_type_length))),
533 namedtype.NamedType('value', char.PrintableString().subtype(subtypeSpec= constraint.ValueSizeConstraint(1, ub_domain_defined_attribute_value_length)))
534 )
535
536 class BuiltInDomainDefinedAttributes(univ.SequenceOf):
537 componentType = BuiltInDomainDefinedAttribute()
538 subtypeSpec = univ.SequenceOf.subtypeSpec + constraint.ValueSizeConstraint(1 , ub_domain_defined_attributes)
539
540 class OrganizationalUnitName(char.PrintableString):
541 subtypeSpec = univ.SequenceOf.subtypeSpec + constraint.ValueSizeConstraint(1 , ub_organizational_unit_name_length)
542
543 class OrganizationalUnitNames(univ.SequenceOf):
544 componentType = OrganizationalUnitName()
545 subtypeSpec = univ.SequenceOf.subtypeSpec + constraint.ValueSizeConstraint(1 , ub_organizational_units)
546
547 class PersonalName(univ.Set):
548 componentType = namedtype.NamedTypes(
549 namedtype.NamedType('surname', char.PrintableString().subtype(subtypeSpe c=constraint.ValueSizeConstraint(1, ub_surname_length), explicitTag=tag.Tag(tag. tagClassContext, tag.tagFormatSimple, 0))),
550 namedtype.OptionalNamedType('given-name', char.PrintableString().subtype (subtypeSpec=constraint.ValueSizeConstraint(1, ub_given_name_length), explicitTa g=tag.Tag(tag.tagClassContext, tag.tagFormatSimple, 1))),
551 namedtype.OptionalNamedType('initials', char.PrintableString().subtype(s ubtypeSpec=constraint.ValueSizeConstraint(1, ub_initials_length), explicitTag=ta g.Tag(tag.tagClassContext, tag.tagFormatSimple, 2))),
552 namedtype.OptionalNamedType('generation-qualifier', char.PrintableString ().subtype(subtypeSpec=constraint.ValueSizeConstraint(1, ub_generation_qualifier _length), explicitTag=tag.Tag(tag.tagClassContext, tag.tagFormatSimple, 3)))
553 )
554
555 class NumericUserIdentifier(char.NumericString):
556 subtypeSpec = char.NumericString.subtypeSpec + constraint.ValueSizeConstrain t(1, ub_numeric_user_id_length)
557
558 class OrganizationName(char.PrintableString):
559 subtypeSpec = char.PrintableString.subtypeSpec + constraint.ValueSizeConstra int(1, ub_organization_name_length)
560
561 class PrivateDomainName(univ.Choice):
562 componentType = namedtype.NamedTypes(
563 namedtype.NamedType('numeric', char.NumericString().subtype(subtypeSpec= constraint.ValueSizeConstraint(1, ub_domain_name_length))),
564 namedtype.NamedType('printable', char.PrintableString().subtype(subtypeS pec=constraint.ValueSizeConstraint(1, ub_domain_name_length)))
565 )
566
567 class TerminalIdentifier(char.PrintableString):
568 subtypeSpec = char.PrintableString.subtypeSpec + constraint.ValueSizeConstra int(1, ub_terminal_id_length)
569
570 class X121Address(char.NumericString):
571 subtypeSpec = char.NumericString.subtypeSpec + constraint.ValueSizeConstrain t(1, ub_x121_address_length)
572
573 class NetworkAddress(X121Address): pass
574
575 class AdministrationDomainName(univ.Choice):
576 tagSet = univ.Choice.tagSet.tagExplicitly(
577 tag.Tag(tag.tagClassApplication, tag.tagFormatConstructed, 2)
578 )
579 componentType = namedtype.NamedTypes(
580 namedtype.NamedType('numeric', char.NumericString().subtype(subtypeSpec= constraint.ValueSizeConstraint(0, ub_domain_name_length))),
581 namedtype.NamedType('printable', char.PrintableString().subtype(subtypeS pec=constraint.ValueSizeConstraint(0, ub_domain_name_length)))
582 )
583
584 class CountryName(univ.Choice):
585 tagSet = univ.Choice.tagSet.tagExplicitly(
586 tag.Tag(tag.tagClassApplication, tag.tagFormatConstructed, 1)
587 )
588 componentType = namedtype.NamedTypes(
589 namedtype.NamedType('x121-dcc-code', char.NumericString().subtype(subtyp eSpec=constraint.ValueSizeConstraint(ub_country_name_numeric_length, ub_country_ name_numeric_length))),
590 namedtype.NamedType('iso-3166-alpha2-code', char.PrintableString().subty pe(subtypeSpec=constraint.ValueSizeConstraint(ub_country_name_alpha_length, ub_c ountry_name_alpha_length)))
591 )
592
593 class BuiltInStandardAttributes(univ.Sequence):
594 componentType = namedtype.NamedTypes(
595 namedtype.OptionalNamedType('country-name', CountryName()),
596 namedtype.OptionalNamedType('administration-domain-name', Administration DomainName()),
597 namedtype.OptionalNamedType('network-address', NetworkAddress().subtype( explicitTag=tag.Tag(tag.tagClassContext, tag.tagFormatSimple, 0))),
598 namedtype.OptionalNamedType('terminal-identifier', TerminalIdentifier(). subtype(explicitTag=tag.Tag(tag.tagClassContext, tag.tagFormatSimple, 1))),
599 namedtype.OptionalNamedType('private-domain-name', PrivateDomainName().s ubtype(explicitTag=tag.Tag(tag.tagClassContext, tag.tagFormatSimple, 2))),
600 namedtype.OptionalNamedType('organization-name', OrganizationName().subt ype(explicitTag=tag.Tag(tag.tagClassContext, tag.tagFormatSimple, 3))),
601 namedtype.OptionalNamedType('numeric-user-identifier', NumericUserIdenti fier().subtype(explicitTag=tag.Tag(tag.tagClassContext, tag.tagFormatSimple, 4)) ),
602 namedtype.OptionalNamedType('personal-name', PersonalName().subtype(expl icitTag=tag.Tag(tag.tagClassContext, tag.tagFormatSimple, 5))),
603 namedtype.OptionalNamedType('organizational-unit-names', OrganizationalU nitNames().subtype(explicitTag=tag.Tag(tag.tagClassContext, tag.tagFormatSimple, 6)))
604 )
605
606 class ORAddress(univ.Sequence):
607 componentType = namedtype.NamedTypes(
608 namedtype.NamedType('built-in-standard-attributes', BuiltInStandardAttri butes()),
609 namedtype.OptionalNamedType('built-in-domain-defined-attributes', BuiltI nDomainDefinedAttributes()),
610 namedtype.OptionalNamedType('extension-attributes', ExtensionAttributes( ))
611 )
612
613 #
614 # PKIX1Implicit88
615 #
616
617 id_ce_invalidityDate = univ.ObjectIdentifier('2.5.29.24')
618
619 class InvalidityDate(useful.GeneralizedTime): pass
620
621 id_holdinstruction_none = univ.ObjectIdentifier('2.2.840.10040.2.1')
622 id_holdinstruction_callissuer = univ.ObjectIdentifier('2.2.840.10040.2.2')
623 id_holdinstruction_reject = univ.ObjectIdentifier('2.2.840.10040.2.3')
624
625 holdInstruction = univ.ObjectIdentifier('2.2.840.10040.2')
626
627 id_ce_holdInstructionCode = univ.ObjectIdentifier('2.5.29.23')
628
629 class HoldInstructionCode(univ.ObjectIdentifier): pass
630
631 id_ce_cRLReasons = univ.ObjectIdentifier('2.5.29.21')
632
633 class CRLReason(univ.Enumerated):
634 namedValues = namedval.NamedValues(
635 ('unspecified', 0),
636 ('keyCompromise', 1),
637 ('cACompromise', 2),
638 ('affiliationChanged', 3),
639 ('superseded', 4),
640 ('cessationOfOperation', 5),
641 ('certificateHold', 6),
642 ('removeFromCRL', 8)
643 )
644
645 id_ce_cRLNumber = univ.ObjectIdentifier('2.5.29.20')
646
647 class CRLNumber(univ.Integer):
648 subtypeSpec = univ.SequenceOf.subtypeSpec + constraint.ValueSizeConstraint(0 , MAX)
649
650 class BaseCRLNumber(CRLNumber): pass
651
652 id_kp_serverAuth = univ.ObjectIdentifier('1.3.6.1.5.5.7.3.1')
653 id_kp_clientAuth = univ.ObjectIdentifier('1.3.6.1.5.5.7.3.2')
654 id_kp_codeSigning = univ.ObjectIdentifier('1.3.6.1.5.5.7.3.3')
655 id_kp_emailProtection = univ.ObjectIdentifier('1.3.6.1.5.5.7.3.4')
656 id_kp_ipsecEndSystem = univ.ObjectIdentifier('1.3.6.1.5.5.7.3.5')
657 id_kp_ipsecTunnel = univ.ObjectIdentifier('1.3.6.1.5.5.7.3.6')
658 id_kp_ipsecUser = univ.ObjectIdentifier('1.3.6.1.5.5.7.3.7')
659 id_kp_timeStamping = univ.ObjectIdentifier('1.3.6.1.5.5.7.3.8')
660 id_pe_authorityInfoAccess = univ.ObjectIdentifier('1.3.6.1.5.5.7.1.1')
661 id_ce_extKeyUsage = univ.ObjectIdentifier('2.5.29.37')
662
663 class KeyPurposeId(univ.ObjectIdentifier): pass
664
665 class ExtKeyUsageSyntax(univ.SequenceOf):
666 componentType = KeyPurposeId()
667 subtypeSpec = univ.SequenceOf.subtypeSpec + constraint.ValueSizeConstraint(1 , MAX)
668
669 class ReasonFlags(univ.BitString):
670 namedValues = namedval.NamedValues(
671 ('unused', 0),
672 ('keyCompromise', 1),
673 ('cACompromise', 2),
674 ('affiliationChanged', 3),
675 ('superseded', 4),
676 ('cessationOfOperation', 5),
677 ('certificateHold', 6)
678 )
679
680
681 class SkipCerts(univ.Integer):
682 subtypeSpec = univ.Integer.subtypeSpec + constraint.ValueSizeConstraint(0, M AX)
683
684 id_ce_policyConstraints = univ.ObjectIdentifier('2.5.29.36')
685
686 class PolicyConstraints(univ.Sequence):
687 componentType = namedtype.NamedTypes(
688 namedtype.OptionalNamedType('requireExplicitPolicy', SkipCerts().subtype (implicitTag=tag.Tag(tag.tagClassContext, tag.tagFormatConstructed, 0))),
689 namedtype.OptionalNamedType('inhibitPolicyMapping', SkipCerts().subtype( implicitTag=tag.Tag(tag.tagClassContext, tag.tagFormatConstructed, 1)))
690 )
691
692 id_ce_basicConstraints = univ.ObjectIdentifier('2.5.29.19')
693
694 class BasicConstraints(univ.Sequence):
695 componentType = namedtype.NamedTypes(
696 namedtype.DefaultedNamedType('cA', univ.Boolean(False)),
697 namedtype.OptionalNamedType('pathLenConstraint', univ.Integer().subtype( subtypeSpec=constraint.ValueRangeConstraint(0, MAX)))
698 )
699
700 id_ce_subjectDirectoryAttributes = univ.ObjectIdentifier('2.5.29.9')
701
702 class SubjectDirectoryAttributes(univ.SequenceOf):
703 componentType = Attribute()
704 subtypeSpec = univ.SequenceOf.subtypeSpec + constraint.ValueSizeConstraint(1 , MAX)
705
706 class EDIPartyName(univ.Sequence):
707 componentType = namedtype.NamedTypes(
708 namedtype.OptionalNamedType('nameAssigner', DirectoryString().subtype(im plicitTag=tag.Tag(tag.tagClassContext, tag.tagFormatSimple, 0))),
709 namedtype.NamedType('partyName', DirectoryString().subtype(implicitTag=t ag.Tag(tag.tagClassContext, tag.tagFormatSimple, 1)))
710 )
711
712 class AnotherName(univ.Sequence):
713 componentType = namedtype.NamedTypes(
714 namedtype.NamedType('type-id', univ.ObjectIdentifier()),
715 namedtype.NamedType('value', univ.Any().subtype(explicitTag=tag.Tag(tag. tagClassContext, tag.tagFormatSimple, 0)))
716 )
717
718 class GeneralName(univ.Choice):
719 componentType = namedtype.NamedTypes(
720 namedtype.NamedType('otherName', AnotherName().subtype(implicitTag=tag.T ag(tag.tagClassContext, tag.tagFormatSimple, 0))),
721 namedtype.NamedType('rfc822Name', char.IA5String().subtype(implicitTag=t ag.Tag(tag.tagClassContext, tag.tagFormatSimple, 1))),
722 namedtype.NamedType('dNSName', char.IA5String().subtype(implicitTag=tag. Tag(tag.tagClassContext, tag.tagFormatSimple, 2))),
723 namedtype.NamedType('x400Address', ORAddress().subtype(implicitTag=tag.T ag(tag.tagClassContext, tag.tagFormatSimple, 3))),
724 namedtype.NamedType('directoryName', Name().subtype(implicitTag=tag.Tag( tag.tagClassContext, tag.tagFormatSimple, 4))),
725 namedtype.NamedType('ediPartyName', EDIPartyName().subtype(implicitTag=t ag.Tag(tag.tagClassContext, tag.tagFormatSimple, 5))),
726 namedtype.NamedType('uniformResourceIdentifier', char.IA5String().subtyp e(implicitTag=tag.Tag(tag.tagClassContext, tag.tagFormatSimple, 6))),
727 namedtype.NamedType('iPAddress', univ.OctetString().subtype(implicitTag= tag.Tag(tag.tagClassContext, tag.tagFormatSimple, 7))),
728 namedtype.NamedType('registeredID', univ.ObjectIdentifier().subtype(impl icitTag=tag.Tag(tag.tagClassContext, tag.tagFormatSimple, 8)))
729 )
730
731 class GeneralNames(univ.SequenceOf):
732 componentType = GeneralName()
733 subtypeSpec = univ.SequenceOf.subtypeSpec + constraint.ValueSizeConstraint(1 , MAX)
734
735 class AccessDescription(univ.Sequence):
736 componentType = namedtype.NamedTypes(
737 namedtype.NamedType('accessMethod', univ.ObjectIdentifier()),
738 namedtype.NamedType('accessLocation', GeneralName())
739 )
740
741 class AuthorityInfoAccessSyntax(univ.SequenceOf):
742 componentType = AccessDescription()
743 subtypeSpec = univ.SequenceOf.subtypeSpec + constraint.ValueSizeConstraint(1 , MAX)
744
745 id_ce_deltaCRLIndicator = univ.ObjectIdentifier('2.5.29.27')
746
747 class DistributionPointName(univ.Choice):
748 componentType = namedtype.NamedTypes(
749 namedtype.NamedType('fullName', GeneralNames().subtype(implicitTag=tag.T ag(tag.tagClassContext, tag.tagFormatConstructed, 0))),
750 namedtype.NamedType('nameRelativeToCRLIssuer', RelativeDistinguishedName ().subtype(implicitTag=tag.Tag(tag.tagClassContext, tag.tagFormatConstructed, 1) ))
751 )
752
753 class DistributionPoint(univ.Sequence):
754 componentType = namedtype.NamedTypes(
755 namedtype.OptionalNamedType('distributionPoint', DistributionPointName() .subtype(implicitTag=tag.Tag(tag.tagClassContext, tag.tagFormatConstructed, 0))) ,
756 namedtype.OptionalNamedType('reasons', ReasonFlags().subtype(implicitTag =tag.Tag(tag.tagClassContext, tag.tagFormatSimple, 1))),
757 namedtype.OptionalNamedType('cRLIssuer', GeneralNames().subtype(implicit Tag=tag.Tag(tag.tagClassContext, tag.tagFormatConstructed, 2)))
758 )
759 class BaseDistance(univ.Integer):
760 subtypeSpec = univ.Integer.subtypeSpec + constraint.ValueRangeConstraint(0, MAX)
761
762 id_ce_cRLDistributionPoints = univ.ObjectIdentifier('2.5.29.31')
763
764 class CRLDistPointsSyntax(univ.SequenceOf):
765 componentType = DistributionPoint()
766 subtypeSpec = univ.SequenceOf.subtypeSpec + constraint.ValueSizeConstraint(1 , MAX)
767 id_ce_issuingDistributionPoint = univ.ObjectIdentifier('2.5.29.28')
768
769 class IssuingDistributionPoint(univ.Sequence):
770 componentType = namedtype.NamedTypes(
771 namedtype.OptionalNamedType('distributionPoint', DistributionPointName() .subtype(implicitTag=tag.Tag(tag.tagClassContext, tag.tagFormatConstructed, 0))) ,
772 namedtype.NamedType('onlyContainsUserCerts', univ.Boolean(False).subtype (implicitTag=tag.Tag(tag.tagClassContext, tag.tagFormatSimple, 1))),
773 namedtype.NamedType('onlyContainsCACerts', univ.Boolean(False).subtype(i mplicitTag=tag.Tag(tag.tagClassContext, tag.tagFormatSimple, 2))),
774 namedtype.OptionalNamedType('onlySomeReasons', ReasonFlags().subtype(imp licitTag=tag.Tag(tag.tagClassContext, tag.tagFormatSimple, 3))),
775 namedtype.NamedType('indirectCRL', univ.Boolean(False).subtype(implicitT ag=tag.Tag(tag.tagClassContext, tag.tagFormatSimple, 4)))
776 )
777
778 class GeneralSubtree(univ.Sequence):
779 componentType = namedtype.NamedTypes(
780 namedtype.NamedType('base', GeneralName()),
781 namedtype.DefaultedNamedType('minimum', BaseDistance(0).subtype(implicit Tag=tag.Tag(tag.tagClassContext, tag.tagFormatConstructed, 0))),
782 namedtype.OptionalNamedType('maximum', BaseDistance().subtype(implicitTa g=tag.Tag(tag.tagClassContext, tag.tagFormatConstructed, 1)))
783 )
784
785 class GeneralSubtrees(univ.SequenceOf):
786 componentType = GeneralSubtree()
787 subtypeSpec = univ.SequenceOf.subtypeSpec + constraint.ValueSizeConstraint(1 , MAX)
788
789 id_ce_nameConstraints = univ.ObjectIdentifier('2.5.29.30')
790
791 class NameConstraints(univ.Sequence):
792 componentType = namedtype.NamedTypes(
793 namedtype.OptionalNamedType('permittedSubtrees', GeneralSubtrees().subty pe(implicitTag=tag.Tag(tag.tagClassContext, tag.tagFormatConstructed, 0))),
794 namedtype.OptionalNamedType('excludedSubtrees', GeneralSubtrees().subtyp e(implicitTag=tag.Tag(tag.tagClassContext, tag.tagFormatConstructed, 1)))
795 )
796
797
798 class DisplayText(univ.Choice):
799 componentType = namedtype.NamedTypes(
800 namedtype.NamedType('visibleString', char.VisibleString().subtype(subtyp eSpec=constraint.ValueSizeConstraint(1, 200))),
801 namedtype.NamedType('bmpString', char.BMPString().subtype(subtypeSpec=co nstraint.ValueSizeConstraint(1, 200))),
802 namedtype.NamedType('utf8String', char.UTF8String().subtype(subtypeSpec= constraint.ValueSizeConstraint(1, 200)))
803 )
804
805 class NoticeReference(univ.Sequence):
806 componentType = namedtype.NamedTypes(
807 namedtype.NamedType('organization', DisplayText()),
808 namedtype.NamedType('noticeNumbers', univ.SequenceOf(componentType=univ. Integer()))
809 )
810
811 class UserNotice(univ.Sequence):
812 componentType = namedtype.NamedTypes(
813 namedtype.OptionalNamedType('noticeRef', NoticeReference()),
814 namedtype.OptionalNamedType('explicitText', DisplayText())
815 )
816
817 class CPSuri(char.IA5String): pass
818
819 class PolicyQualifierId(univ.ObjectIdentifier):
820 subtypeSpec = univ.ObjectIdentifier.subtypeSpec + constraint.SingleValueCons traint(id_qt_cps, id_qt_unotice)
821
822 class CertPolicyId(univ.ObjectIdentifier): pass
823
824 class PolicyQualifierInfo(univ.Sequence):
825 componentType = namedtype.NamedTypes(
826 namedtype.NamedType('policyQualifierId', PolicyQualifierId()),
827 namedtype.NamedType('qualifier', univ.Any())
828 )
829
830 id_ce_certificatePolicies = univ.ObjectIdentifier('2.5.29.32')
831
832 class PolicyInformation(univ.Sequence):
833 componentType = namedtype.NamedTypes(
834 namedtype.NamedType('policyIdentifier', CertPolicyId()),
835 namedtype.OptionalNamedType('policyQualifiers', univ.SequenceOf(componen tType=PolicyQualifierInfo()).subtype(subtypeSpec=constraint.ValueSizeConstraint( 1, MAX)))
836 )
837
838 class CertificatePolicies(univ.SequenceOf):
839 componentType = PolicyInformation()
840 subtypeSpec = univ.SequenceOf.subtypeSpec + constraint.ValueSizeConstraint(1 , MAX)
841
842 id_ce_policyMappings = univ.ObjectIdentifier('2.5.29.33')
843
844 class PolicyMapping(univ.Sequence):
845 componentType = namedtype.NamedTypes(
846 namedtype.NamedType('issuerDomainPolicy', CertPolicyId()),
847 namedtype.NamedType('subjectDomainPolicy', CertPolicyId())
848 )
849
850 class PolicyMappings(univ.SequenceOf):
851 componentType = PolicyMapping()
852 subtypeSpec = univ.SequenceOf.subtypeSpec + constraint.ValueSizeConstraint(1 , MAX)
853
854 id_ce_privateKeyUsagePeriod = univ.ObjectIdentifier('2.5.29.16')
855
856 class PrivateKeyUsagePeriod(univ.Sequence):
857 componentType = namedtype.NamedTypes(
858 namedtype.OptionalNamedType('notBefore', useful.GeneralizedTime().subtyp e(implicitTag=tag.Tag(tag.tagClassContext, tag.tagFormatSimple, 0))),
859 namedtype.OptionalNamedType('notAfter', useful.GeneralizedTime().subtype (implicitTag=tag.Tag(tag.tagClassContext, tag.tagFormatSimple, 1)))
860 )
861
862 id_ce_keyUsage = univ.ObjectIdentifier('2.5.29.15')
863
864 class KeyUsage(univ.BitString):
865 namedValues = namedval.NamedValues(
866 ('digitalSignature', 0),
867 ('nonRepudiation', 1),
868 ('keyEncipherment', 2),
869 ('dataEncipherment', 3),
870 ('keyAgreement', 4),
871 ('keyCertSign', 5),
872 ('cRLSign', 6),
873 ('encipherOnly', 7),
874 ('decipherOnly', 8)
875 )
876
877 id_ce = univ.ObjectIdentifier('2.5.29')
878
879 id_ce_authorityKeyIdentifier = univ.ObjectIdentifier('2.5.29.35')
880
881 class KeyIdentifier(univ.OctetString): pass
882
883 id_ce_subjectKeyIdentifier = univ.ObjectIdentifier('2.5.29.14')
884
885 class SubjectKeyIdentifier(KeyIdentifier): pass
886
887 class AuthorityKeyIdentifier(univ.Sequence):
888 componentType = namedtype.NamedTypes(
889 namedtype.OptionalNamedType('keyIdentifier', KeyIdentifier().subtype(imp licitTag=tag.Tag(tag.tagClassContext, tag.tagFormatSimple, 0))),
890 namedtype.OptionalNamedType('authorityCertIssuer', GeneralNames().subtyp e(implicitTag=tag.Tag(tag.tagClassContext, tag.tagFormatSimple, 1))),
891 namedtype.OptionalNamedType('authorityCertSerialNumber', CertificateSeri alNumber().subtype(implicitTag=tag.Tag(tag.tagClassContext, tag.tagFormatSimple, 2)))
892 )
893
894 id_ce_certificateIssuer = univ.ObjectIdentifier('2.5.29.29')
895
896 class CertificateIssuer(GeneralNames): pass
897
898 id_ce_subjectAltName = univ.ObjectIdentifier('2.5.29.17')
899
900 class SubjectAltName(GeneralNames): pass
901
902 id_ce_issuerAltName = univ.ObjectIdentifier('2.5.29.18')
903
904 class IssuerAltName(GeneralNames): pass
OLDNEW
« no previous file with comments | « third_party/google-endpoints/pyasn1_modules/rfc2437.py ('k') | third_party/google-endpoints/pyasn1_modules/rfc2511.py » ('j') | no next file with comments »

Powered by Google App Engine
This is Rietveld 408576698