You can not select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
161 lines
4.1 KiB
161 lines
4.1 KiB
#if !BESTHTTP_DISABLE_ALTERNATE_SSL && (!UNITY_WEBGL || UNITY_EDITOR) |
|
#pragma warning disable |
|
using System; |
|
using System.Collections; |
|
|
|
using BestHTTP.SecureProtocol.Org.BouncyCastle.Asn1.Ocsp; |
|
using BestHTTP.SecureProtocol.Org.BouncyCastle.Asn1.X509; |
|
using BestHTTP.SecureProtocol.Org.BouncyCastle.Utilities.Collections; |
|
|
|
namespace BestHTTP.SecureProtocol.Org.BouncyCastle.Asn1.Esf |
|
{ |
|
/// <remarks> |
|
/// RFC 5126: 6.3.4. revocation-values Attribute Definition |
|
/// <code> |
|
/// RevocationValues ::= SEQUENCE { |
|
/// crlVals [0] SEQUENCE OF CertificateList OPTIONAL, |
|
/// ocspVals [1] SEQUENCE OF BasicOCSPResponse OPTIONAL, |
|
/// otherRevVals [2] OtherRevVals OPTIONAL |
|
/// } |
|
/// </code> |
|
/// </remarks> |
|
public class RevocationValues |
|
: Asn1Encodable |
|
{ |
|
private readonly Asn1Sequence crlVals; |
|
private readonly Asn1Sequence ocspVals; |
|
private readonly OtherRevVals otherRevVals; |
|
|
|
public static RevocationValues GetInstance( |
|
object obj) |
|
{ |
|
if (obj == null || obj is RevocationValues) |
|
return (RevocationValues) obj; |
|
|
|
return new RevocationValues(Asn1Sequence.GetInstance(obj)); |
|
} |
|
|
|
private RevocationValues( |
|
Asn1Sequence seq) |
|
{ |
|
if (seq == null) |
|
throw new ArgumentNullException("seq"); |
|
if (seq.Count > 3) |
|
throw new ArgumentException("Bad sequence size: " + seq.Count, "seq"); |
|
|
|
foreach (Asn1TaggedObject taggedObj in seq) |
|
{ |
|
Asn1Object asn1Obj = taggedObj.GetObject(); |
|
switch (taggedObj.TagNo) |
|
{ |
|
case 0: |
|
Asn1Sequence crlValsSeq = (Asn1Sequence) asn1Obj; |
|
foreach (Asn1Encodable ae in crlValsSeq) |
|
{ |
|
CertificateList.GetInstance(ae.ToAsn1Object()); |
|
} |
|
this.crlVals = crlValsSeq; |
|
break; |
|
case 1: |
|
Asn1Sequence ocspValsSeq = (Asn1Sequence) asn1Obj; |
|
foreach (Asn1Encodable ae in ocspValsSeq) |
|
{ |
|
BasicOcspResponse.GetInstance(ae.ToAsn1Object()); |
|
} |
|
this.ocspVals = ocspValsSeq; |
|
break; |
|
case 2: |
|
this.otherRevVals = OtherRevVals.GetInstance(asn1Obj); |
|
break; |
|
default: |
|
throw new ArgumentException("Illegal tag in RevocationValues", "seq"); |
|
} |
|
} |
|
} |
|
|
|
public RevocationValues( |
|
CertificateList[] crlVals, |
|
BasicOcspResponse[] ocspVals, |
|
OtherRevVals otherRevVals) |
|
{ |
|
if (crlVals != null) |
|
{ |
|
this.crlVals = new DerSequence(crlVals); |
|
} |
|
|
|
if (ocspVals != null) |
|
{ |
|
this.ocspVals = new DerSequence(ocspVals); |
|
} |
|
|
|
this.otherRevVals = otherRevVals; |
|
} |
|
|
|
public RevocationValues( |
|
IEnumerable crlVals, |
|
IEnumerable ocspVals, |
|
OtherRevVals otherRevVals) |
|
{ |
|
if (crlVals != null) |
|
{ |
|
if (!CollectionUtilities.CheckElementsAreOfType(crlVals, typeof(CertificateList))) |
|
throw new ArgumentException("Must contain only 'CertificateList' objects", "crlVals"); |
|
|
|
this.crlVals = new DerSequence( |
|
Asn1EncodableVector.FromEnumerable(crlVals)); |
|
} |
|
|
|
if (ocspVals != null) |
|
{ |
|
if (!CollectionUtilities.CheckElementsAreOfType(ocspVals, typeof(BasicOcspResponse))) |
|
throw new ArgumentException("Must contain only 'BasicOcspResponse' objects", "ocspVals"); |
|
|
|
this.ocspVals = new DerSequence( |
|
Asn1EncodableVector.FromEnumerable(ocspVals)); |
|
} |
|
|
|
this.otherRevVals = otherRevVals; |
|
} |
|
|
|
public CertificateList[] GetCrlVals() |
|
{ |
|
CertificateList[] result = new CertificateList[crlVals.Count]; |
|
for (int i = 0; i < crlVals.Count; ++i) |
|
{ |
|
result[i] = CertificateList.GetInstance(crlVals[i].ToAsn1Object()); |
|
} |
|
return result; |
|
} |
|
|
|
public BasicOcspResponse[] GetOcspVals() |
|
{ |
|
BasicOcspResponse[] result = new BasicOcspResponse[ocspVals.Count]; |
|
for (int i = 0; i < ocspVals.Count; ++i) |
|
{ |
|
result[i] = BasicOcspResponse.GetInstance(ocspVals[i].ToAsn1Object()); |
|
} |
|
return result; |
|
} |
|
|
|
public OtherRevVals OtherRevVals |
|
{ |
|
get { return otherRevVals; } |
|
} |
|
|
|
public override Asn1Object ToAsn1Object() |
|
{ |
|
Asn1EncodableVector v = new Asn1EncodableVector(); |
|
v.AddOptionalTagged(true, 0, crlVals); |
|
v.AddOptionalTagged(true, 1, ocspVals); |
|
|
|
if (otherRevVals != null) |
|
{ |
|
v.Add(new DerTaggedObject(true, 2, otherRevVals.ToAsn1Object())); |
|
} |
|
|
|
return new DerSequence(v); |
|
} |
|
} |
|
} |
|
#pragma warning restore |
|
#endif
|
|
|