123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293 |
- #if !BESTHTTP_DISABLE_ALTERNATE_SSL && (!UNITY_WEBGL || UNITY_EDITOR)
- #pragma warning disable
- using System;
- using BestHTTP.SecureProtocol.Org.BouncyCastle.Asn1.X509;
- using BestHTTP.SecureProtocol.Org.BouncyCastle.Utilities;
- namespace BestHTTP.SecureProtocol.Org.BouncyCastle.Asn1.Ess
- {
- public class EssCertID
- : Asn1Encodable
- {
- private Asn1OctetString certHash;
- private IssuerSerial issuerSerial;
- public static EssCertID GetInstance(
- object o)
- {
- if (o == null || o is EssCertID)
- {
- return (EssCertID) o;
- }
- if (o is Asn1Sequence)
- {
- return new EssCertID((Asn1Sequence) o);
- }
- throw new ArgumentException(
- "unknown object in 'EssCertID' factory : "
- + BestHTTP.SecureProtocol.Org.BouncyCastle.Utilities.Platform.GetTypeName(o) + ".");
- }
- /**
- * constructor
- */
- public EssCertID(
- Asn1Sequence seq)
- {
- if (seq.Count < 1 || seq.Count > 2)
- {
- throw new ArgumentException("Bad sequence size: " + seq.Count);
- }
- this.certHash = Asn1OctetString.GetInstance(seq[0]);
- if (seq.Count > 1)
- {
- issuerSerial = IssuerSerial.GetInstance(seq[1]);
- }
- }
- public EssCertID(
- byte[] hash)
- {
- certHash = new DerOctetString(hash);
- }
- public EssCertID(
- byte[] hash,
- IssuerSerial issuerSerial)
- {
- this.certHash = new DerOctetString(hash);
- this.issuerSerial = issuerSerial;
- }
- public byte[] GetCertHash()
- {
- return certHash.GetOctets();
- }
- public IssuerSerial IssuerSerial
- {
- get { return issuerSerial; }
- }
- /**
- * <pre>
- * EssCertID ::= SEQUENCE {
- * certHash Hash,
- * issuerSerial IssuerSerial OPTIONAL }
- * </pre>
- */
- public override Asn1Object ToAsn1Object()
- {
- Asn1EncodableVector v = new Asn1EncodableVector(certHash);
- v.AddOptional(issuerSerial);
- return new DerSequence(v);
- }
- }
- }
- #pragma warning restore
- #endif
|