Files
SuperVPN/output/Libraries/BouncyCastle.Crypto/Org/BouncyCastle/Asn1/Ess/SigningCertificate.cs
2025-10-09 09:57:24 +09:00

78 lines
1.7 KiB
C#

using System;
using Org.BouncyCastle.Asn1.X509;
using Org.BouncyCastle.Utilities;
namespace Org.BouncyCastle.Asn1.Ess;
public class SigningCertificate : Asn1Encodable
{
private Asn1Sequence certs;
private Asn1Sequence policies;
public static SigningCertificate GetInstance(object o)
{
if (o == null || o is SigningCertificate)
{
return (SigningCertificate)o;
}
if (o is Asn1Sequence)
{
return new SigningCertificate((Asn1Sequence)o);
}
throw new ArgumentException("unknown object in 'SigningCertificate' factory : " + Platform.GetTypeName(o) + ".");
}
public SigningCertificate(Asn1Sequence seq)
{
if (seq.Count < 1 || seq.Count > 2)
{
throw new ArgumentException("Bad sequence size: " + seq.Count);
}
certs = Asn1Sequence.GetInstance(seq[0]);
if (seq.Count > 1)
{
policies = Asn1Sequence.GetInstance(seq[1]);
}
}
public SigningCertificate(EssCertID essCertID)
{
certs = new DerSequence(essCertID);
}
public EssCertID[] GetCerts()
{
EssCertID[] array = new EssCertID[certs.Count];
for (int i = 0; i != certs.Count; i++)
{
array[i] = EssCertID.GetInstance(certs[i]);
}
return array;
}
public PolicyInformation[] GetPolicies()
{
if (policies == null)
{
return null;
}
PolicyInformation[] array = new PolicyInformation[policies.Count];
for (int i = 0; i != policies.Count; i++)
{
array[i] = PolicyInformation.GetInstance(policies[i]);
}
return array;
}
public override Asn1Object ToAsn1Object()
{
Asn1EncodableVector asn1EncodableVector = new Asn1EncodableVector(certs);
if (policies != null)
{
asn1EncodableVector.Add(policies);
}
return new DerSequence(asn1EncodableVector);
}
}