399 lines
12 KiB
Python
399 lines
12 KiB
Python
|
#
|
||
|
# 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
|
||
|
#
|
||
|
# An Internet Attribute Certificate Profile for Authorization
|
||
|
#
|
||
|
# ASN.1 source from:
|
||
|
# https://www.rfc-editor.org/rfc/rfc5755.txt
|
||
|
# https://www.rfc-editor.org/rfc/rfc5912.txt (see Section 13)
|
||
|
#
|
||
|
|
||
|
from pyasn1.type import char
|
||
|
from pyasn1.type import constraint
|
||
|
from pyasn1.type import namedtype
|
||
|
from pyasn1.type import namedval
|
||
|
from pyasn1.type import opentype
|
||
|
from pyasn1.type import tag
|
||
|
from pyasn1.type import univ
|
||
|
from pyasn1.type import useful
|
||
|
|
||
|
from pyasn1_modules import rfc5280
|
||
|
from pyasn1_modules import rfc5652
|
||
|
|
||
|
MAX = float('inf')
|
||
|
|
||
|
# Map for Security Category type to value
|
||
|
|
||
|
securityCategoryMap = { }
|
||
|
|
||
|
|
||
|
# Imports from RFC 5652
|
||
|
|
||
|
ContentInfo = rfc5652.ContentInfo
|
||
|
|
||
|
|
||
|
# Imports from RFC 5280
|
||
|
|
||
|
AlgorithmIdentifier = rfc5280.AlgorithmIdentifier
|
||
|
|
||
|
Attribute = rfc5280.Attribute
|
||
|
|
||
|
AuthorityInfoAccessSyntax = rfc5280.AuthorityInfoAccessSyntax
|
||
|
|
||
|
AuthorityKeyIdentifier = rfc5280.AuthorityKeyIdentifier
|
||
|
|
||
|
CertificateSerialNumber = rfc5280.CertificateSerialNumber
|
||
|
|
||
|
CRLDistributionPoints = rfc5280.CRLDistributionPoints
|
||
|
|
||
|
Extensions = rfc5280.Extensions
|
||
|
|
||
|
Extension = rfc5280.Extension
|
||
|
|
||
|
GeneralNames = rfc5280.GeneralNames
|
||
|
|
||
|
GeneralName = rfc5280.GeneralName
|
||
|
|
||
|
UniqueIdentifier = rfc5280.UniqueIdentifier
|
||
|
|
||
|
|
||
|
# Object Identifier arcs
|
||
|
|
||
|
id_pkix = univ.ObjectIdentifier((1, 3, 6, 1, 5, 5, 7, ))
|
||
|
|
||
|
id_pe = id_pkix + (1, )
|
||
|
|
||
|
id_kp = id_pkix + (3, )
|
||
|
|
||
|
id_aca = id_pkix + (10, )
|
||
|
|
||
|
id_ad = id_pkix + (48, )
|
||
|
|
||
|
id_at = univ.ObjectIdentifier((2, 5, 4, ))
|
||
|
|
||
|
id_ce = univ.ObjectIdentifier((2, 5, 29, ))
|
||
|
|
||
|
|
||
|
# Attribute Certificate
|
||
|
|
||
|
class AttCertVersion(univ.Integer):
|
||
|
namedValues = namedval.NamedValues(
|
||
|
('v2', 1)
|
||
|
)
|
||
|
|
||
|
|
||
|
class IssuerSerial(univ.Sequence):
|
||
|
componentType = namedtype.NamedTypes(
|
||
|
namedtype.NamedType('issuer', GeneralNames()),
|
||
|
namedtype.NamedType('serial', CertificateSerialNumber()),
|
||
|
namedtype.OptionalNamedType('issuerUID', UniqueIdentifier())
|
||
|
)
|
||
|
|
||
|
|
||
|
class ObjectDigestInfo(univ.Sequence):
|
||
|
componentType = namedtype.NamedTypes(
|
||
|
namedtype.NamedType('digestedObjectType',
|
||
|
univ.Enumerated(namedValues=namedval.NamedValues(
|
||
|
('publicKey', 0),
|
||
|
('publicKeyCert', 1),
|
||
|
('otherObjectTypes', 2)))),
|
||
|
namedtype.OptionalNamedType('otherObjectTypeID',
|
||
|
univ.ObjectIdentifier()),
|
||
|
namedtype.NamedType('digestAlgorithm',
|
||
|
AlgorithmIdentifier()),
|
||
|
namedtype.NamedType('objectDigest',
|
||
|
univ.BitString())
|
||
|
)
|
||
|
|
||
|
|
||
|
class Holder(univ.Sequence):
|
||
|
componentType = namedtype.NamedTypes(
|
||
|
namedtype.OptionalNamedType('baseCertificateID',
|
||
|
IssuerSerial().subtype(implicitTag=tag.Tag(
|
||
|
tag.tagClassContext, tag.tagFormatConstructed, 0))),
|
||
|
namedtype.OptionalNamedType('entityName',
|
||
|
GeneralNames().subtype(implicitTag=tag.Tag(
|
||
|
tag.tagClassContext, tag.tagFormatSimple, 1))),
|
||
|
namedtype.OptionalNamedType('objectDigestInfo',
|
||
|
ObjectDigestInfo().subtype(implicitTag=tag.Tag(
|
||
|
tag.tagClassContext, tag.tagFormatConstructed, 2)))
|
||
|
)
|
||
|
|
||
|
|
||
|
class V2Form(univ.Sequence):
|
||
|
componentType = namedtype.NamedTypes(
|
||
|
namedtype.OptionalNamedType('issuerName',
|
||
|
GeneralNames()),
|
||
|
namedtype.OptionalNamedType('baseCertificateID',
|
||
|
IssuerSerial().subtype(implicitTag=tag.Tag(
|
||
|
tag.tagClassContext, tag.tagFormatConstructed, 0))),
|
||
|
namedtype.OptionalNamedType('objectDigestInfo',
|
||
|
ObjectDigestInfo().subtype(implicitTag=tag.Tag(
|
||
|
tag.tagClassContext, tag.tagFormatConstructed, 1)))
|
||
|
)
|
||
|
|
||
|
|
||
|
class AttCertIssuer(univ.Choice):
|
||
|
componentType = namedtype.NamedTypes(
|
||
|
namedtype.NamedType('v1Form', GeneralNames()),
|
||
|
namedtype.NamedType('v2Form', V2Form().subtype(implicitTag=tag.Tag(
|
||
|
tag.tagClassContext, tag.tagFormatConstructed, 0)))
|
||
|
)
|
||
|
|
||
|
|
||
|
class AttCertValidityPeriod(univ.Sequence):
|
||
|
componentType = namedtype.NamedTypes(
|
||
|
namedtype.NamedType('notBeforeTime', useful.GeneralizedTime()),
|
||
|
namedtype.NamedType('notAfterTime', useful.GeneralizedTime())
|
||
|
)
|
||
|
|
||
|
|
||
|
class AttributeCertificateInfo(univ.Sequence):
|
||
|
componentType = namedtype.NamedTypes(
|
||
|
namedtype.NamedType('version',
|
||
|
AttCertVersion()),
|
||
|
namedtype.NamedType('holder',
|
||
|
Holder()),
|
||
|
namedtype.NamedType('issuer',
|
||
|
AttCertIssuer()),
|
||
|
namedtype.NamedType('signature',
|
||
|
AlgorithmIdentifier()),
|
||
|
namedtype.NamedType('serialNumber',
|
||
|
CertificateSerialNumber()),
|
||
|
namedtype.NamedType('attrCertValidityPeriod',
|
||
|
AttCertValidityPeriod()),
|
||
|
namedtype.NamedType('attributes',
|
||
|
univ.SequenceOf(componentType=Attribute())),
|
||
|
namedtype.OptionalNamedType('issuerUniqueID',
|
||
|
UniqueIdentifier()),
|
||
|
namedtype.OptionalNamedType('extensions',
|
||
|
Extensions())
|
||
|
)
|
||
|
|
||
|
|
||
|
class AttributeCertificate(univ.Sequence):
|
||
|
componentType = namedtype.NamedTypes(
|
||
|
namedtype.NamedType('acinfo', AttributeCertificateInfo()),
|
||
|
namedtype.NamedType('signatureAlgorithm', AlgorithmIdentifier()),
|
||
|
namedtype.NamedType('signatureValue', univ.BitString())
|
||
|
)
|
||
|
|
||
|
|
||
|
# Attribute Certificate Extensions
|
||
|
|
||
|
id_pe_ac_auditIdentity = id_pe + (4, )
|
||
|
|
||
|
id_ce_noRevAvail = id_ce + (56, )
|
||
|
|
||
|
id_ce_targetInformation = id_ce + (55, )
|
||
|
|
||
|
|
||
|
class TargetCert(univ.Sequence):
|
||
|
componentType = namedtype.NamedTypes(
|
||
|
namedtype.NamedType('targetCertificate', IssuerSerial()),
|
||
|
namedtype.OptionalNamedType('targetName', GeneralName()),
|
||
|
namedtype.OptionalNamedType('certDigestInfo', ObjectDigestInfo())
|
||
|
)
|
||
|
|
||
|
|
||
|
class Target(univ.Choice):
|
||
|
componentType = namedtype.NamedTypes(
|
||
|
namedtype.NamedType('targetName',
|
||
|
GeneralName().subtype(implicitTag=tag.Tag(
|
||
|
tag.tagClassContext, tag.tagFormatSimple, 0))),
|
||
|
namedtype.NamedType('targetGroup',
|
||
|
GeneralName().subtype(implicitTag=tag.Tag(
|
||
|
tag.tagClassContext, tag.tagFormatSimple, 1))),
|
||
|
namedtype.NamedType('targetCert',
|
||
|
TargetCert().subtype(implicitTag=tag.Tag(
|
||
|
tag.tagClassContext, tag.tagFormatConstructed, 2)))
|
||
|
)
|
||
|
|
||
|
|
||
|
class Targets(univ.SequenceOf):
|
||
|
componentType = Target()
|
||
|
|
||
|
|
||
|
id_pe_ac_proxying = id_pe + (10, )
|
||
|
|
||
|
|
||
|
class ProxyInfo(univ.SequenceOf):
|
||
|
componentType = Targets()
|
||
|
|
||
|
|
||
|
id_pe_aaControls = id_pe + (6, )
|
||
|
|
||
|
|
||
|
class AttrSpec(univ.SequenceOf):
|
||
|
componentType = univ.ObjectIdentifier()
|
||
|
|
||
|
|
||
|
class AAControls(univ.Sequence):
|
||
|
componentType = namedtype.NamedTypes(
|
||
|
namedtype.OptionalNamedType('pathLenConstraint',
|
||
|
univ.Integer().subtype(
|
||
|
subtypeSpec=constraint.ValueRangeConstraint(0, MAX))),
|
||
|
namedtype.OptionalNamedType('permittedAttrs',
|
||
|
AttrSpec().subtype(implicitTag=tag.Tag(
|
||
|
tag.tagClassContext, tag.tagFormatSimple, 0))),
|
||
|
namedtype.OptionalNamedType('excludedAttrs',
|
||
|
AttrSpec().subtype(implicitTag=tag.Tag(
|
||
|
tag.tagClassContext, tag.tagFormatSimple, 1))),
|
||
|
namedtype.DefaultedNamedType('permitUnSpecified',
|
||
|
univ.Boolean().subtype(value=1))
|
||
|
)
|
||
|
|
||
|
|
||
|
# Attribute Certificate Attributes
|
||
|
|
||
|
id_aca_authenticationInfo = id_aca + (1, )
|
||
|
|
||
|
|
||
|
id_aca_accessIdentity = id_aca + (2, )
|
||
|
|
||
|
|
||
|
class SvceAuthInfo(univ.Sequence):
|
||
|
componentType = namedtype.NamedTypes(
|
||
|
namedtype.NamedType('service', GeneralName()),
|
||
|
namedtype.NamedType('ident', GeneralName()),
|
||
|
namedtype.OptionalNamedType('authInfo', univ.OctetString())
|
||
|
)
|
||
|
|
||
|
|
||
|
id_aca_chargingIdentity = id_aca + (3, )
|
||
|
|
||
|
|
||
|
id_aca_group = id_aca + (4, )
|
||
|
|
||
|
|
||
|
class IetfAttrSyntax(univ.Sequence):
|
||
|
componentType = namedtype.NamedTypes(
|
||
|
namedtype.OptionalNamedType('policyAuthority',
|
||
|
GeneralNames().subtype(implicitTag=tag.Tag(
|
||
|
tag.tagClassContext, tag.tagFormatSimple, 0))),
|
||
|
namedtype.NamedType('values', univ.SequenceOf(
|
||
|
componentType=univ.Choice(componentType=namedtype.NamedTypes(
|
||
|
namedtype.NamedType('octets', univ.OctetString()),
|
||
|
namedtype.NamedType('oid', univ.ObjectIdentifier()),
|
||
|
namedtype.NamedType('string', char.UTF8String())
|
||
|
))
|
||
|
))
|
||
|
)
|
||
|
|
||
|
|
||
|
id_at_role = id_at + (72,)
|
||
|
|
||
|
|
||
|
class RoleSyntax(univ.Sequence):
|
||
|
componentType = namedtype.NamedTypes(
|
||
|
namedtype.OptionalNamedType('roleAuthority',
|
||
|
GeneralNames().subtype(implicitTag=tag.Tag(
|
||
|
tag.tagClassContext, tag.tagFormatSimple, 0))),
|
||
|
namedtype.NamedType('roleName',
|
||
|
GeneralName().subtype(implicitTag=tag.Tag(
|
||
|
tag.tagClassContext, tag.tagFormatSimple, 1)))
|
||
|
)
|
||
|
|
||
|
|
||
|
class ClassList(univ.BitString):
|
||
|
namedValues = namedval.NamedValues(
|
||
|
('unmarked', 0),
|
||
|
('unclassified', 1),
|
||
|
('restricted', 2),
|
||
|
('confidential', 3),
|
||
|
('secret', 4),
|
||
|
('topSecret', 5)
|
||
|
)
|
||
|
|
||
|
|
||
|
class SecurityCategory(univ.Sequence):
|
||
|
componentType = namedtype.NamedTypes(
|
||
|
namedtype.NamedType('type',
|
||
|
univ.ObjectIdentifier().subtype(implicitTag=tag.Tag(
|
||
|
tag.tagClassContext, tag.tagFormatSimple, 0))),
|
||
|
namedtype.NamedType('value',
|
||
|
univ.Any().subtype(implicitTag=tag.Tag(
|
||
|
tag.tagClassContext, tag.tagFormatSimple, 1)),
|
||
|
openType=opentype.OpenType('type', securityCategoryMap))
|
||
|
)
|
||
|
|
||
|
|
||
|
id_at_clearance = univ.ObjectIdentifier((2, 5, 4, 55, ))
|
||
|
|
||
|
|
||
|
class Clearance(univ.Sequence):
|
||
|
componentType = namedtype.NamedTypes(
|
||
|
namedtype.NamedType('policyId',
|
||
|
univ.ObjectIdentifier()),
|
||
|
namedtype.DefaultedNamedType('classList',
|
||
|
ClassList().subtype(value='unclassified')),
|
||
|
namedtype.OptionalNamedType('securityCategories',
|
||
|
univ.SetOf(componentType=SecurityCategory()))
|
||
|
)
|
||
|
|
||
|
|
||
|
id_at_clearance_rfc3281 = univ.ObjectIdentifier((2, 5, 1, 5, 55, ))
|
||
|
|
||
|
|
||
|
class Clearance_rfc3281(univ.Sequence):
|
||
|
componentType = namedtype.NamedTypes(
|
||
|
namedtype.NamedType('policyId',
|
||
|
univ.ObjectIdentifier().subtype(implicitTag=tag.Tag(
|
||
|
tag.tagClassContext, tag.tagFormatSimple, 0))),
|
||
|
namedtype.DefaultedNamedType('classList',
|
||
|
ClassList().subtype(implicitTag=tag.Tag(
|
||
|
tag.tagClassContext, tag.tagFormatSimple, 1)).subtype(
|
||
|
value='unclassified')),
|
||
|
namedtype.OptionalNamedType('securityCategories',
|
||
|
univ.SetOf(componentType=SecurityCategory()).subtype(
|
||
|
implicitTag=tag.Tag(
|
||
|
tag.tagClassContext, tag.tagFormatSimple, 2)))
|
||
|
)
|
||
|
|
||
|
|
||
|
id_aca_encAttrs = id_aca + (6, )
|
||
|
|
||
|
|
||
|
class ACClearAttrs(univ.Sequence):
|
||
|
componentType = namedtype.NamedTypes(
|
||
|
namedtype.NamedType('acIssuer', GeneralName()),
|
||
|
namedtype.NamedType('acSerial', univ.Integer()),
|
||
|
namedtype.NamedType('attrs', univ.SequenceOf(componentType=Attribute()))
|
||
|
)
|
||
|
|
||
|
|
||
|
# Map of Certificate Extension OIDs to Extensions added to the
|
||
|
# ones that are in rfc5280.py
|
||
|
|
||
|
_certificateExtensionsMapUpdate = {
|
||
|
id_pe_ac_auditIdentity: univ.OctetString(),
|
||
|
id_ce_noRevAvail: univ.Null(),
|
||
|
id_ce_targetInformation: Targets(),
|
||
|
id_pe_ac_proxying: ProxyInfo(),
|
||
|
id_pe_aaControls: AAControls(),
|
||
|
}
|
||
|
|
||
|
rfc5280.certificateExtensionsMap.update(_certificateExtensionsMapUpdate)
|
||
|
|
||
|
|
||
|
# Map of AttributeType OIDs to AttributeValue added to the
|
||
|
# ones that are in rfc5280.py
|
||
|
|
||
|
_certificateAttributesMapUpdate = {
|
||
|
id_aca_authenticationInfo: SvceAuthInfo(),
|
||
|
id_aca_accessIdentity: SvceAuthInfo(),
|
||
|
id_aca_chargingIdentity: IetfAttrSyntax(),
|
||
|
id_aca_group: IetfAttrSyntax(),
|
||
|
id_at_role: RoleSyntax(),
|
||
|
id_at_clearance: Clearance(),
|
||
|
id_at_clearance_rfc3281: Clearance_rfc3281(),
|
||
|
id_aca_encAttrs: ContentInfo(),
|
||
|
}
|
||
|
|
||
|
rfc5280.certificateAttributesMap.update(_certificateAttributesMapUpdate)
|