12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970 |
- # This file is being contributed to pyasn1-modules software.
- #
- # Created by Russ Housley.
- #
- # Copyright (c) 2019, Vigil Security, LLC
- # License: http://snmplabs.com/pyasn1/license.html
- #
- # Other Certificates Extension
- #
- # ASN.1 source from:
- # https://www.rfc-editor.org/rfc/rfc5697.txt
- from pyasn1.type import namedtype
- from pyasn1.type import univ
- from pyasn1_modules import rfc5280
- from pyasn1_modules import rfc4055
- # Imports from RFC 5280
- AlgorithmIdentifier = rfc5280.AlgorithmIdentifier
- CertificateSerialNumber = rfc5280.CertificateSerialNumber
- GeneralNames = rfc5280.GeneralNames
- # Imports from RFC 4055
- id_sha1 = rfc4055.id_sha1
- # Imports from RFC 5055
- # These are defined here because a module for RFC 5055 does not exist yet
- class SCVPIssuerSerial(univ.Sequence):
- componentType = namedtype.NamedTypes(
- namedtype.NamedType('issuer', GeneralNames()),
- namedtype.NamedType('serialNumber', CertificateSerialNumber())
- )
- sha1_alg_id = AlgorithmIdentifier()
- sha1_alg_id['algorithm'] = id_sha1
- class SCVPCertID(univ.Sequence):
- componentType = namedtype.NamedTypes(
- namedtype.NamedType('certHash', univ.OctetString()),
- namedtype.NamedType('issuerSerial', SCVPIssuerSerial()),
- namedtype.DefaultedNamedType('hashAlgorithm', sha1_alg_id)
- )
- # Other Certificates Extension
- id_pe_otherCerts = univ.ObjectIdentifier((1, 3, 6, 1, 5, 5, 7, 1, 19,))
- class OtherCertificates(univ.SequenceOf):
- componentType = SCVPCertID()
- # Update of certificate extension map in rfc5280.py
- _certificateExtensionsMapUpdate = {
- id_pe_otherCerts: OtherCertificates(),
- }
- rfc5280.certificateExtensionsMap.update(_certificateExtensionsMapUpdate)
|