CertificationRequest.componentType = namedtype.NamedTypes( namedtype.NamedType( 'certificationRequestInfo', univ.Sequence(componentType=namedtype.NamedTypes( namedtype.NamedType('version', univ.Integer()), namedtype.NamedType('subject', rfc5280.Name()), namedtype.NamedType( 'subjectPublicKeyInfo', univ.Sequence(componentType=namedtype.NamedTypes( namedtype.NamedType('algorithm', rfc5280.AlgorithmIdentifier()), namedtype.NamedType('subjectPublicKey', univ.BitString())))), namedtype.NamedType( 'attributes', univ.SetOf(componentType=rfc5652.Attribute()).subtype( implicitTag=tag.Tag(tag.tagClassContext, tag.tagFormatSimple, 0)))))), namedtype.NamedType('signatureAlgorithm', rfc5280.AlgorithmIdentifier()), namedtype.NamedType('signature', univ.BitString())) class TaggedCertificationRequest(univ.Sequence): pass TaggedCertificationRequest.componentType = namedtype.NamedTypes( namedtype.NamedType('bodyPartID', BodyPartID()), namedtype.NamedType('certificationRequest', CertificationRequest()))
def setUp(self): self.asn1Spec = rfc5652.Attribute()
namedtype.NamedType( 'certificationRequestInfo', univ.Sequence( componentType=namedtype.NamedTypes( namedtype.NamedType('version', univ.Integer()), namedtype.NamedType('subject', rfc5280.Name()), namedtype.NamedType( 'subjectPublicKeyInfo', univ.Sequence( componentType=namedtype.NamedTypes( namedtype.NamedType('algorithm', rfc5280.AlgorithmIdentifier()), namedtype.NamedType('subjectPublicKey', univ.BitString()) ) ) ), namedtype.NamedType( 'attributes', univ.SetOf( componentType=rfc5652.Attribute()).subtype( implicitTag=tag.Tag(tag.tagClassContext, tag.tagFormatSimple, 0)) ) ) ) ), namedtype.NamedType('signatureAlgorithm', rfc5280.AlgorithmIdentifier()), namedtype.NamedType('signature', univ.BitString()) ) class TaggedCertificationRequest(univ.Sequence): pass TaggedCertificationRequest.componentType = namedtype.NamedTypes(
namedtype.OptionalNamedType('signatureAlgorithm', SignatureAlgorithmIdentifier().subtype( implicitTag=tag.Tag(tag.tagClassContext, tag.tagFormatSimple, 1))), namedtype.OptionalNamedType('macAlgorithm', MessageAuthenticationCodeAlgorithm().subtype( implicitTag=tag.Tag(tag.tagClassContext, tag.tagFormatSimple, 2))) ) CMSAlgorithmProtection.subtypeSpec = constraint.ConstraintsUnion( constraint.WithComponentsConstraint( ('signatureAlgorithm', constraint.ComponentPresentConstraint()), ('macAlgorithm', constraint.ComponentAbsentConstraint())), constraint.WithComponentsConstraint( ('signatureAlgorithm', constraint.ComponentAbsentConstraint()), ('macAlgorithm', constraint.ComponentPresentConstraint())) ) aa_cmsAlgorithmProtection = rfc5652.Attribute() aa_cmsAlgorithmProtection['attrType'] = id_aa_cmsAlgorithmProtect aa_cmsAlgorithmProtection['attrValues'][0] = CMSAlgorithmProtection() # Map of Attribute Type OIDs to Attributes are # added to the ones that are in rfc5652.py _cmsAttributesMapUpdate = { id_aa_cmsAlgorithmProtect: CMSAlgorithmProtection(), } rfc5652.cmsAttributesMap.update(_cmsAttributesMapUpdate)
from pyasn1.type import namedtype from pyasn1.type import univ from pyasn1_modules import rfc5652 id_attr_validation_parameters = univ.ObjectIdentifier( '1.3.6.1.4.1.2312.18.8.1') class ValidationParams(univ.Sequence): pass ValidationParams.componentType = namedtype.NamedTypes( namedtype.NamedType('hashAlg', univ.ObjectIdentifier()), namedtype.NamedType('seed', univ.OctetString())) at_validation_parameters = rfc5652.Attribute() at_validation_parameters['attrType'] = id_attr_validation_parameters at_validation_parameters['attrValues'][0] = ValidationParams() # Map of Attribute Type OIDs to Attributes added to the # ones that are in rfc5652.py _cmsAttributesMapUpdate = { id_attr_validation_parameters: ValidationParams(), } rfc5652.cmsAttributesMap.update(_cmsAttributesMapUpdate)
namedtype.NamedType('universalString', char.UniversalString().subtype( subtypeSpec=constraint.ValueSizeConstraint(1, 255))), namedtype.NamedType('utf8String', char.UTF8String().subtype( subtypeSpec=constraint.ValueSizeConstraint(1, 255))), namedtype.NamedType('bmpString', char.BMPString().subtype( subtypeSpec=constraint.ValueSizeConstraint(1, 255))) ) # OTP Challenge Attribute id_aa_otpChallenge = univ.ObjectIdentifier('1.2.840.113549.1.9.16.2.56') ub_aa_otpChallenge = univ.Integer(255) otpChallenge = rfc5652.Attribute() otpChallenge['attrType'] = id_aa_otpChallenge otpChallenge['attrValues'][0] = DirectoryString() # Revocation Challenge Attribute id_aa_revocationChallenge = univ.ObjectIdentifier('1.2.840.113549.1.9.16.2.57') ub_aa_revocationChallenge = univ.Integer(255) revocationChallenge = rfc5652.Attribute() revocationChallenge['attrType'] = id_aa_revocationChallenge revocationChallenge['attrValues'][0] = DirectoryString()
class Attributes(univ.SetOf): componentType = rfc5652.Attribute()
from pyasn1.type import tag from pyasn1.type import univ from pyasn1_modules import rfc5652 from pyasn1_modules import rfc5083 # Content Decryption Key Identifier attribute id_aa_KP_contentDecryptKeyID = univ.ObjectIdentifier('2.16.840.1.101.2.1.5.66') class ContentDecryptKeyID(univ.OctetString): pass aa_content_decrypt_key_identifier = rfc5652.Attribute() aa_content_decrypt_key_identifier['attrType'] = id_aa_KP_contentDecryptKeyID aa_content_decrypt_key_identifier['attrValues'][0] = ContentDecryptKeyID() # Encrypted Key Package Content Type id_ct_KP_encryptedKeyPkg = univ.ObjectIdentifier('2.16.840.1.101.2.1.2.78.2') class EncryptedKeyPackage(univ.Choice): pass EncryptedKeyPackage.componentType = namedtype.NamedTypes( namedtype.NamedType('encrypted', rfc5652.EncryptedData()), namedtype.NamedType(