60 lines
1.5 KiB
C#
60 lines
1.5 KiB
C#
#if !BESTHTTP_DISABLE_ALTERNATE_SSL && (!UNITY_WEBGL || UNITY_EDITOR)
|
|
#pragma warning disable
|
|
using System;
|
|
|
|
using BestHTTP.SecureProtocol.Org.BouncyCastle.Asn1.Crmf;
|
|
using BestHTTP.SecureProtocol.Org.BouncyCastle.Asn1.X509;
|
|
|
|
namespace BestHTTP.SecureProtocol.Org.BouncyCastle.Asn1.Cmp
|
|
{
|
|
public class RevRepContentBuilder
|
|
{
|
|
private readonly Asn1EncodableVector m_status = new Asn1EncodableVector();
|
|
private readonly Asn1EncodableVector m_revCerts = new Asn1EncodableVector();
|
|
private readonly Asn1EncodableVector m_crls = new Asn1EncodableVector();
|
|
|
|
public virtual RevRepContentBuilder Add(PkiStatusInfo status)
|
|
{
|
|
m_status.Add(status);
|
|
return this;
|
|
}
|
|
|
|
public virtual RevRepContentBuilder Add(PkiStatusInfo status, CertId certId)
|
|
{
|
|
if (m_status.Count != m_revCerts.Count)
|
|
throw new InvalidOperationException("status and revCerts sequence must be in common order");
|
|
|
|
m_status.Add(status);
|
|
m_revCerts.Add(certId);
|
|
return this;
|
|
}
|
|
|
|
public virtual RevRepContentBuilder AddCrl(CertificateList crl)
|
|
{
|
|
m_crls.Add(crl);
|
|
return this;
|
|
}
|
|
|
|
public virtual RevRepContent Build()
|
|
{
|
|
Asn1EncodableVector v = new Asn1EncodableVector();
|
|
|
|
v.Add(new DerSequence(m_status));
|
|
|
|
if (m_revCerts.Count != 0)
|
|
{
|
|
v.Add(new DerTaggedObject(true, 0, new DerSequence(m_revCerts)));
|
|
}
|
|
|
|
if (m_crls.Count != 0)
|
|
{
|
|
v.Add(new DerTaggedObject(true, 1, new DerSequence(m_crls)));
|
|
}
|
|
|
|
return RevRepContent.GetInstance(new DerSequence(v));
|
|
}
|
|
}
|
|
}
|
|
#pragma warning restore
|
|
#endif
|