Coverage for /pythoncovmergedfiles/medio/medio/usr/local/lib/python3.8/site-packages/pyasn1_modules/rfc2511.py: 100%
71 statements
« prev ^ index » next coverage.py v7.2.2, created at 2023-03-26 06:04 +0000
« prev ^ index » next coverage.py v7.2.2, created at 2023-03-26 06:04 +0000
1#
2# This file is part of pyasn1-modules software.
3#
4# Copyright (c) 2005-2020, Ilya Etingof <etingof@gmail.com>
5# License: http://snmplabs.com/pyasn1/license.html
6#
7# X.509 certificate Request Message Format (CRMF) syntax
8#
9# ASN.1 source from:
10# http://tools.ietf.org/html/rfc2511
11#
12# Sample captures could be obtained with OpenSSL
13#
14from pyasn1_modules import rfc2315
15from pyasn1_modules.rfc2459 import *
17MAX = float('inf')
19id_pkix = univ.ObjectIdentifier('1.3.6.1.5.5.7')
20id_pkip = univ.ObjectIdentifier('1.3.6.1.5.5.7.5')
21id_regCtrl = univ.ObjectIdentifier('1.3.6.1.5.5.7.5.1')
22id_regCtrl_regToken = univ.ObjectIdentifier('1.3.6.1.5.5.7.5.1.1')
23id_regCtrl_authenticator = univ.ObjectIdentifier('1.3.6.1.5.5.7.5.1.2')
24id_regCtrl_pkiPublicationInfo = univ.ObjectIdentifier('1.3.6.1.5.5.7.5.1.3')
25id_regCtrl_pkiArchiveOptions = univ.ObjectIdentifier('1.3.6.1.5.5.7.5.1.4')
26id_regCtrl_oldCertID = univ.ObjectIdentifier('1.3.6.1.5.5.7.5.1.5')
27id_regCtrl_protocolEncrKey = univ.ObjectIdentifier('1.3.6.1.5.5.7.5.1.6')
28id_regInfo = univ.ObjectIdentifier('1.3.6.1.5.5.7.5.2')
29id_regInfo_utf8Pairs = univ.ObjectIdentifier('1.3.6.1.5.5.7.5.2.1')
30id_regInfo_certReq = univ.ObjectIdentifier('1.3.6.1.5.5.7.5.2.2')
33# This should be in PKIX Certificate Extensions module
35class GeneralName(univ.OctetString):
36 pass
39# end of PKIX Certificate Extensions module
41class UTF8Pairs(char.UTF8String):
42 pass
45class ProtocolEncrKey(SubjectPublicKeyInfo):
46 pass
49class CertId(univ.Sequence):
50 componentType = namedtype.NamedTypes(
51 namedtype.NamedType('issuer', GeneralName()),
52 namedtype.NamedType('serialNumber', univ.Integer())
53 )
56class OldCertId(CertId):
57 pass
60class KeyGenParameters(univ.OctetString):
61 pass
64class EncryptedValue(univ.Sequence):
65 componentType = namedtype.NamedTypes(
66 namedtype.OptionalNamedType('intendedAlg', AlgorithmIdentifier().subtype(
67 implicitTag=tag.Tag(tag.tagClassContext, tag.tagFormatConstructed, 0))),
68 namedtype.OptionalNamedType('symmAlg', AlgorithmIdentifier().subtype(
69 implicitTag=tag.Tag(tag.tagClassContext, tag.tagFormatConstructed, 1))),
70 namedtype.OptionalNamedType('encSymmKey', univ.BitString().subtype(
71 implicitTag=tag.Tag(tag.tagClassContext, tag.tagFormatConstructed, 2))),
72 namedtype.OptionalNamedType('keyAlg', AlgorithmIdentifier().subtype(
73 implicitTag=tag.Tag(tag.tagClassContext, tag.tagFormatConstructed, 3))),
74 namedtype.OptionalNamedType('valueHint', univ.OctetString().subtype(
75 implicitTag=tag.Tag(tag.tagClassContext, tag.tagFormatConstructed, 4))),
76 namedtype.NamedType('encValue', univ.BitString())
77 )
80class EncryptedKey(univ.Choice):
81 componentType = namedtype.NamedTypes(
82 namedtype.NamedType('encryptedValue', EncryptedValue()),
83 namedtype.NamedType('envelopedData', rfc2315.EnvelopedData().subtype(
84 implicitTag=tag.Tag(tag.tagClassContext, tag.tagFormatConstructed, 0)))
85 )
88class PKIArchiveOptions(univ.Choice):
89 componentType = namedtype.NamedTypes(
90 namedtype.NamedType('encryptedPrivKey', EncryptedKey().subtype(
91 implicitTag=tag.Tag(tag.tagClassContext, tag.tagFormatConstructed, 0))),
92 namedtype.NamedType('keyGenParameters', KeyGenParameters().subtype(
93 implicitTag=tag.Tag(tag.tagClassContext, tag.tagFormatSimple, 1))),
94 namedtype.NamedType('archiveRemGenPrivKey',
95 univ.Boolean().subtype(implicitTag=tag.Tag(tag.tagClassContext, tag.tagFormatSimple, 2)))
96 )
99class SinglePubInfo(univ.Sequence):
100 componentType = namedtype.NamedTypes(
101 namedtype.NamedType('pubMethod', univ.Integer(
102 namedValues=namedval.NamedValues(('dontCare', 0), ('x500', 1), ('web', 2), ('ldap', 3)))),
103 namedtype.OptionalNamedType('pubLocation', GeneralName())
104 )
107class PKIPublicationInfo(univ.Sequence):
108 componentType = namedtype.NamedTypes(
109 namedtype.NamedType('action',
110 univ.Integer(namedValues=namedval.NamedValues(('dontPublish', 0), ('pleasePublish', 1)))),
111 namedtype.OptionalNamedType('pubInfos', univ.SequenceOf(componentType=SinglePubInfo()).subtype(
112 sizeSpec=constraint.ValueSizeConstraint(1, MAX)))
113 )
116class Authenticator(char.UTF8String):
117 pass
120class RegToken(char.UTF8String):
121 pass
124class SubsequentMessage(univ.Integer):
125 namedValues = namedval.NamedValues(
126 ('encrCert', 0),
127 ('challengeResp', 1)
128 )
131class POPOPrivKey(univ.Choice):
132 componentType = namedtype.NamedTypes(
133 namedtype.NamedType('thisMessage',
134 univ.BitString().subtype(implicitTag=tag.Tag(tag.tagClassContext, tag.tagFormatSimple, 0))),
135 namedtype.NamedType('subsequentMessage', SubsequentMessage().subtype(
136 implicitTag=tag.Tag(tag.tagClassContext, tag.tagFormatSimple, 1))),
137 namedtype.NamedType('dhMAC',
138 univ.BitString().subtype(implicitTag=tag.Tag(tag.tagClassContext, tag.tagFormatSimple, 2)))
139 )
142class PBMParameter(univ.Sequence):
143 componentType = namedtype.NamedTypes(
144 namedtype.NamedType('salt', univ.OctetString()),
145 namedtype.NamedType('owf', AlgorithmIdentifier()),
146 namedtype.NamedType('iterationCount', univ.Integer()),
147 namedtype.NamedType('mac', AlgorithmIdentifier())
148 )
151class PKMACValue(univ.Sequence):
152 componentType = namedtype.NamedTypes(
153 namedtype.NamedType('algId', AlgorithmIdentifier()),
154 namedtype.NamedType('value', univ.BitString())
155 )
158class POPOSigningKeyInput(univ.Sequence):
159 componentType = namedtype.NamedTypes(
160 namedtype.NamedType(
161 'authInfo', univ.Choice(
162 componentType=namedtype.NamedTypes(
163 namedtype.NamedType(
164 'sender', GeneralName().subtype(implicitTag=tag.Tag(tag.tagClassContext, tag.tagFormatSimple, 0))
165 ),
166 namedtype.NamedType('publicKeyMAC', PKMACValue())
167 )
168 )
169 ),
170 namedtype.NamedType('publicKey', SubjectPublicKeyInfo())
171 )
174class POPOSigningKey(univ.Sequence):
175 componentType = namedtype.NamedTypes(
176 namedtype.OptionalNamedType('poposkInput', POPOSigningKeyInput().subtype(
177 implicitTag=tag.Tag(tag.tagClassContext, tag.tagFormatConstructed, 0))),
178 namedtype.NamedType('algorithmIdentifier', AlgorithmIdentifier()),
179 namedtype.NamedType('signature', univ.BitString())
180 )
183class ProofOfPossession(univ.Choice):
184 componentType = namedtype.NamedTypes(
185 namedtype.NamedType('raVerified',
186 univ.Null().subtype(implicitTag=tag.Tag(tag.tagClassContext, tag.tagFormatSimple, 0))),
187 namedtype.NamedType('signature', POPOSigningKey().subtype(
188 implicitTag=tag.Tag(tag.tagClassContext, tag.tagFormatConstructed, 1))),
189 namedtype.NamedType('keyEncipherment', POPOPrivKey().subtype(
190 implicitTag=tag.Tag(tag.tagClassContext, tag.tagFormatConstructed, 2))),
191 namedtype.NamedType('keyAgreement', POPOPrivKey().subtype(
192 implicitTag=tag.Tag(tag.tagClassContext, tag.tagFormatConstructed, 3)))
193 )
196class Controls(univ.SequenceOf):
197 componentType = AttributeTypeAndValue()
198 sizeSpec = univ.SequenceOf.sizeSpec + constraint.ValueSizeConstraint(1, MAX)
201class OptionalValidity(univ.Sequence):
202 componentType = namedtype.NamedTypes(
203 namedtype.OptionalNamedType('notBefore',
204 Time().subtype(implicitTag=tag.Tag(tag.tagClassContext, tag.tagFormatSimple, 0))),
205 namedtype.OptionalNamedType('notAfter',
206 Time().subtype(implicitTag=tag.Tag(tag.tagClassContext, tag.tagFormatSimple, 1)))
207 )
210class CertTemplate(univ.Sequence):
211 componentType = namedtype.NamedTypes(
212 namedtype.OptionalNamedType('version', Version().subtype(
213 implicitTag=tag.Tag(tag.tagClassContext, tag.tagFormatSimple, 0))),
214 namedtype.OptionalNamedType('serialNumber', univ.Integer().subtype(
215 implicitTag=tag.Tag(tag.tagClassContext, tag.tagFormatSimple, 1))),
216 namedtype.OptionalNamedType('signingAlg', AlgorithmIdentifier().subtype(
217 implicitTag=tag.Tag(tag.tagClassContext, tag.tagFormatConstructed, 2))),
218 namedtype.OptionalNamedType('issuer', Name().subtype(
219 implicitTag=tag.Tag(tag.tagClassContext, tag.tagFormatConstructed, 3))),
220 namedtype.OptionalNamedType('validity', OptionalValidity().subtype(
221 implicitTag=tag.Tag(tag.tagClassContext, tag.tagFormatConstructed, 4))),
222 namedtype.OptionalNamedType('subject', Name().subtype(
223 implicitTag=tag.Tag(tag.tagClassContext, tag.tagFormatConstructed, 5))),
224 namedtype.OptionalNamedType('publicKey', SubjectPublicKeyInfo().subtype(
225 implicitTag=tag.Tag(tag.tagClassContext, tag.tagFormatConstructed, 6))),
226 namedtype.OptionalNamedType('issuerUID', UniqueIdentifier().subtype(
227 implicitTag=tag.Tag(tag.tagClassContext, tag.tagFormatSimple, 7))),
228 namedtype.OptionalNamedType('subjectUID', UniqueIdentifier().subtype(
229 implicitTag=tag.Tag(tag.tagClassContext, tag.tagFormatSimple, 8))),
230 namedtype.OptionalNamedType('extensions', Extensions().subtype(
231 implicitTag=tag.Tag(tag.tagClassContext, tag.tagFormatConstructed, 9)))
232 )
235class CertRequest(univ.Sequence):
236 componentType = namedtype.NamedTypes(
237 namedtype.NamedType('certReqId', univ.Integer()),
238 namedtype.NamedType('certTemplate', CertTemplate()),
239 namedtype.OptionalNamedType('controls', Controls())
240 )
243class CertReq(CertRequest):
244 pass
247class CertReqMsg(univ.Sequence):
248 componentType = namedtype.NamedTypes(
249 namedtype.NamedType('certReq', CertRequest()),
250 namedtype.OptionalNamedType('pop', ProofOfPossession()),
251 namedtype.OptionalNamedType('regInfo', univ.SequenceOf(componentType=AttributeTypeAndValue()).subtype(
252 sizeSpec=constraint.ValueSizeConstraint(1, MAX)))
253 )
256class CertReqMessages(univ.SequenceOf):
257 componentType = CertReqMsg()
258 sizeSpec = univ.SequenceOf.sizeSpec + constraint.ValueSizeConstraint(1, MAX)