123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157 |
- #
- # This file is part of pyasn1-modules software.
- #
- # Created by Russ Housley with assistance from asn1ate v.0.6.0.
- #
- # Copyright (c) 2019, Vigil Security, LLC
- # License: http://snmplabs.com/pyasn1/license.html
- #
- # Elliptic Curve Cryptography (ECC) Algorithms in the CMS
- #
- # ASN.1 source from:
- # https://www.rfc-editor.org/rfc/rfc5753.txt
- #
- from pyasn1.type import univ, char, namedtype, namedval, tag, constraint, useful
- from pyasn1_modules import rfc5280
- from pyasn1_modules import rfc5480
- from pyasn1_modules import rfc5652
- from pyasn1_modules import rfc5751
- from pyasn1_modules import rfc8018
- # Imports from RFC 5280
- AlgorithmIdentifier = rfc5280.AlgorithmIdentifier
- # Imports from RFC 5652
- OriginatorPublicKey = rfc5652.OriginatorPublicKey
- UserKeyingMaterial = rfc5652.UserKeyingMaterial
- # Imports from RFC 5480
- ECDSA_Sig_Value = rfc5480.ECDSA_Sig_Value
- ECParameters = rfc5480.ECParameters
- ECPoint = rfc5480.ECPoint
- id_ecPublicKey = rfc5480.id_ecPublicKey
- # Imports from RFC 8018
- id_hmacWithSHA224 = rfc8018.id_hmacWithSHA224
- id_hmacWithSHA256 = rfc8018.id_hmacWithSHA256
- id_hmacWithSHA384 = rfc8018.id_hmacWithSHA384
- id_hmacWithSHA512 = rfc8018.id_hmacWithSHA512
- # Object Identifier arcs
- x9_63_scheme = univ.ObjectIdentifier('1.3.133.16.840.63.0')
- secg_scheme = univ.ObjectIdentifier('1.3.132.1')
- # Object Identifiers for the algorithms
- dhSinglePass_cofactorDH_sha1kdf_scheme = x9_63_scheme + (3, )
- dhSinglePass_cofactorDH_sha224kdf_scheme = secg_scheme + (14, 0, )
- dhSinglePass_cofactorDH_sha256kdf_scheme = secg_scheme + (14, 1, )
- dhSinglePass_cofactorDH_sha384kdf_scheme = secg_scheme + (14, 2, )
- dhSinglePass_cofactorDH_sha512kdf_scheme = secg_scheme + (14, 3, )
- dhSinglePass_stdDH_sha1kdf_scheme = x9_63_scheme + (2, )
- dhSinglePass_stdDH_sha224kdf_scheme = secg_scheme + (11, 0, )
- dhSinglePass_stdDH_sha256kdf_scheme = secg_scheme + (11, 1, )
- dhSinglePass_stdDH_sha384kdf_scheme = secg_scheme + (11, 2, )
- dhSinglePass_stdDH_sha512kdf_scheme = secg_scheme + (11, 3, )
- mqvSinglePass_sha1kdf_scheme = x9_63_scheme + (16, )
- mqvSinglePass_sha224kdf_scheme = secg_scheme + (15, 0, )
- mqvSinglePass_sha256kdf_scheme = secg_scheme + (15, 1, )
- mqvSinglePass_sha384kdf_scheme = secg_scheme + (15, 2, )
- mqvSinglePass_sha512kdf_scheme = secg_scheme + (15, 3, )
- # Structures for parameters and key derivation
- class IV(univ.OctetString):
- # Exactly 8 octets
- pass
- class CBCParameter(IV):
- pass
- class KeyWrapAlgorithm(AlgorithmIdentifier):
- pass
- class ECC_CMS_SharedInfo(univ.Sequence):
- componentType = namedtype.NamedTypes(
- namedtype.NamedType('keyInfo', KeyWrapAlgorithm()),
- namedtype.OptionalNamedType('entityUInfo',
- univ.OctetString().subtype(explicitTag=tag.Tag(
- tag.tagClassContext, tag.tagFormatSimple, 0))),
- namedtype.NamedType('suppPubInfo',
- univ.OctetString().subtype(explicitTag=tag.Tag(
- tag.tagClassContext, tag.tagFormatSimple, 2)))
- )
- class MQVuserKeyingMaterial(univ.Sequence):
- componentType = namedtype.NamedTypes(
- namedtype.NamedType('ephemeralPublicKey', OriginatorPublicKey()),
- namedtype.OptionalNamedType('addedukm',
- UserKeyingMaterial().subtype(explicitTag=tag.Tag(
- tag.tagClassContext, tag.tagFormatSimple, 0)))
- )
- # Update the Algorithm Identifier map in rfc5280.py and
- # Update the SMIMECapabilities Attribute Map in rfc5751.py
- _algorithmIdentifierMapUpdate = {
- dhSinglePass_stdDH_sha1kdf_scheme: KeyWrapAlgorithm(),
- dhSinglePass_stdDH_sha224kdf_scheme: KeyWrapAlgorithm(),
- dhSinglePass_stdDH_sha256kdf_scheme: KeyWrapAlgorithm(),
- dhSinglePass_stdDH_sha384kdf_scheme: KeyWrapAlgorithm(),
- dhSinglePass_stdDH_sha512kdf_scheme: KeyWrapAlgorithm(),
- dhSinglePass_cofactorDH_sha1kdf_scheme: KeyWrapAlgorithm(),
- dhSinglePass_cofactorDH_sha224kdf_scheme: KeyWrapAlgorithm(),
- dhSinglePass_cofactorDH_sha256kdf_scheme: KeyWrapAlgorithm(),
- dhSinglePass_cofactorDH_sha384kdf_scheme: KeyWrapAlgorithm(),
- dhSinglePass_cofactorDH_sha512kdf_scheme: KeyWrapAlgorithm(),
- mqvSinglePass_sha1kdf_scheme: KeyWrapAlgorithm(),
- mqvSinglePass_sha224kdf_scheme: KeyWrapAlgorithm(),
- mqvSinglePass_sha256kdf_scheme: KeyWrapAlgorithm(),
- mqvSinglePass_sha384kdf_scheme: KeyWrapAlgorithm(),
- mqvSinglePass_sha512kdf_scheme: KeyWrapAlgorithm(),
- }
- rfc5280.algorithmIdentifierMap.update(_algorithmIdentifierMapUpdate)
- rfc5751.smimeCapabilityMap.update(_algorithmIdentifierMapUpdate)
|