mirrored from https://www.bouncycastle.org/repositories/bc-csharp
-
Notifications
You must be signed in to change notification settings - Fork 602
Expand file tree
/
Copy pathX509V2AttributeCertificateGenerator.cs
More file actions
115 lines (94 loc) · 4.15 KB
/
Copy pathX509V2AttributeCertificateGenerator.cs
File metadata and controls
115 lines (94 loc) · 4.15 KB
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
using System;
using System.Collections.Generic;
using Org.BouncyCastle.Asn1;
using Org.BouncyCastle.Asn1.X509;
using Org.BouncyCastle.Crypto;
using Org.BouncyCastle.Math;
namespace Org.BouncyCastle.X509
{
/// <remarks>Class to produce an X.509 Version 2 AttributeCertificate.</remarks>
public class X509V2AttributeCertificateGenerator
{
private readonly X509ExtensionsGenerator m_extGenerator = new X509ExtensionsGenerator();
private V2AttributeCertificateInfoGenerator m_acInfoGen;
public X509V2AttributeCertificateGenerator()
{
m_acInfoGen = new V2AttributeCertificateInfoGenerator();
}
/// <summary>Reset the generator</summary>
public void Reset()
{
m_acInfoGen = new V2AttributeCertificateInfoGenerator();
m_extGenerator.Reset();
}
/// <summary>Set the Holder of this Attribute Certificate.</summary>
public void SetHolder(AttributeCertificateHolder holder)
{
m_acInfoGen.SetHolder(holder.m_holder);
}
/// <summary>Set the issuer.</summary>
public void SetIssuer(AttributeCertificateIssuer issuer)
{
m_acInfoGen.SetIssuer(AttCertIssuer.GetInstance(issuer.form));
}
/// <summary>Set the serial number for the certificate.</summary>
public void SetSerialNumber(BigInteger serialNumber)
{
m_acInfoGen.SetSerialNumber(new DerInteger(serialNumber));
}
public void SetNotBefore(DateTime date)
{
m_acInfoGen.SetStartDate(Rfc5280Asn1Utilities.CreateGeneralizedTime(date));
}
public void SetNotAfter(DateTime date)
{
m_acInfoGen.SetEndDate(Rfc5280Asn1Utilities.CreateGeneralizedTime(date));
}
/// <summary>Add an attribute.</summary>
public void AddAttribute(X509Attribute attribute)
{
m_acInfoGen.AddAttribute(AttributeX509.GetInstance(attribute.ToAsn1Object()));
}
public void SetIssuerUniqueId(bool[] iui)
{
m_acInfoGen.SetIssuerUniqueID(X509V3CertificateGenerator.BooleanToBitString(iui));
}
/// <summary>Add a given extension field for the standard extensions tag.</summary>
public void AddExtension(string oid, bool critical, Asn1Encodable extensionValue)
{
m_extGenerator.AddExtension(new DerObjectIdentifier(oid), critical, extensionValue);
}
/// <summary>
/// Add a given extension field for the standard extensions tag.
/// The value parameter becomes the contents of the octet string associated
/// with the extension.
/// </summary>
public void AddExtension(string oid, bool critical, byte[] extensionValue)
{
m_extGenerator.AddExtension(new DerObjectIdentifier(oid), critical, extensionValue);
}
/// <summary>
/// Generate a new <see cref="X509V2AttributeCertificate"/> using the provided <see cref="ISignatureFactory"/>.
/// </summary>
/// <param name="signatureFactory">A <see cref="ISignatureFactory">signature factory</see> with the necessary
/// algorithm details.</param>
/// <returns>An <see cref="X509V2AttributeCertificate"/>.</returns>
public X509V2AttributeCertificate Generate(ISignatureFactory signatureFactory)
{
var sigAlgID = (AlgorithmIdentifier)signatureFactory.AlgorithmDetails;
m_acInfoGen.SetSignature(sigAlgID);
if (!m_extGenerator.IsEmpty)
{
m_acInfoGen.SetExtensions(m_extGenerator.Generate());
}
var acInfo = m_acInfoGen.GenerateAttributeCertificateInfo();
var signature = X509Utilities.GenerateSignature(signatureFactory, acInfo);
return new X509V2AttributeCertificate(new AttributeCertificate(acInfo, sigAlgID, signature));
}
/// <summary>
/// Allows enumeration of the signature names supported by the generator.
/// </summary>
[Obsolete("Will be removed")]
public IEnumerable<string> SignatureAlgNames => X509Utilities.GetAlgNames();
}
}