#if !BESTHTTP_DISABLE_ALTERNATE_SSL && (!UNITY_WEBGL || UNITY_EDITOR) #pragma warning disable using System; using System.Collections; using BestHTTP.SecureProtocol.Org.BouncyCastle.Math; namespace BestHTTP.SecureProtocol.Org.BouncyCastle.Asn1.X509 { /** * NoticeReference class, used in * CertificatePolicies X509 V3 extensions * (in policy qualifiers). * *
     *  NoticeReference ::= Sequence {
     *      organization     DisplayText,
     *      noticeNumbers    Sequence OF Integer }
     *
     * 
* * @see PolicyQualifierInfo * @see PolicyInformation */ public class NoticeReference : Asn1Encodable { private readonly DisplayText organization; private readonly Asn1Sequence noticeNumbers; private static Asn1EncodableVector ConvertVector(IList numbers) { Asn1EncodableVector av = new Asn1EncodableVector(); foreach (object o in numbers) { DerInteger di; if (o is BigInteger) { di = new DerInteger((BigInteger)o); } else if (o is int) { di = new DerInteger((int)o); } else { throw new ArgumentException(); } av.Add(di); } return av; } /** * Creates a new NoticeReference instance. * * @param organization a String value * @param numbers a Vector value */ public NoticeReference(string organization, IList numbers) : this(organization, ConvertVector(numbers)) { } /** * Creates a new NoticeReference instance. * * @param organization a String value * @param noticeNumbers an ASN1EncodableVector value */ public NoticeReference(string organization, Asn1EncodableVector noticeNumbers) : this(new DisplayText(organization), noticeNumbers) { } /** * Creates a new NoticeReference instance. * * @param organization displayText * @param noticeNumbers an ASN1EncodableVector value */ public NoticeReference(DisplayText organization, Asn1EncodableVector noticeNumbers) { this.organization = organization; this.noticeNumbers = new DerSequence(noticeNumbers); } /** * Creates a new NoticeReference instance. *

Useful for reconstructing a NoticeReference * instance from its encodable/encoded form.

* * @param as an Asn1Sequence value obtained from either * calling @{link ToAsn1Object()} for a NoticeReference * instance or from parsing it from a Der-encoded stream. */ private NoticeReference(Asn1Sequence seq) { if (seq.Count != 2) throw new ArgumentException("Bad sequence size: " + seq.Count, "seq"); organization = DisplayText.GetInstance(seq[0]); noticeNumbers = Asn1Sequence.GetInstance(seq[1]); } public static NoticeReference GetInstance(object obj) { if (obj is NoticeReference) return (NoticeReference)obj; if (obj == null) return null; return new NoticeReference(Asn1Sequence.GetInstance(obj)); } public virtual DisplayText Organization { get { return organization; } } public virtual DerInteger[] GetNoticeNumbers() { DerInteger[] tmp = new DerInteger[noticeNumbers.Count]; for (int i = 0; i != noticeNumbers.Count; ++i) { tmp[i] = DerInteger.GetInstance(noticeNumbers[i]); } return tmp; } /** * Describe ToAsn1Object method here. * * @return a Asn1Object value */ public override Asn1Object ToAsn1Object() { return new DerSequence(organization, noticeNumbers); } } } #pragma warning restore #endif