rfc2459.py 48 KB

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