#if !BESTHTTP_DISABLE_ALTERNATE_SSL && (!UNITY_WEBGL || UNITY_EDITOR) #pragma warning disable using System; using System.Collections; using BestHTTP.SecureProtocol.Org.BouncyCastle.Utilities; namespace BestHTTP.SecureProtocol.Org.BouncyCastle.Asn1.Cms { public class ContentInfo : Asn1Encodable { private readonly DerObjectIdentifier contentType; private readonly Asn1Encodable content; public static ContentInfo GetInstance( object obj) { if (obj == null || obj is ContentInfo) return (ContentInfo) obj; if (obj is Asn1Sequence) return new ContentInfo((Asn1Sequence) obj); throw new ArgumentException("unknown object in factory: " + BestHTTP.SecureProtocol.Org.BouncyCastle.Utilities.Platform.GetTypeName(obj)); } public static ContentInfo GetInstance(Asn1TaggedObject obj, bool isExplicit) { return GetInstance(Asn1Sequence.GetInstance(obj, isExplicit)); } private ContentInfo( Asn1Sequence seq) { if (seq.Count < 1 || seq.Count > 2) throw new ArgumentException("Bad sequence size: " + seq.Count, "seq"); contentType = (DerObjectIdentifier) seq[0]; if (seq.Count > 1) { Asn1TaggedObject tagged = (Asn1TaggedObject) seq[1]; if (!tagged.IsExplicit() || tagged.TagNo != 0) throw new ArgumentException("Bad tag for 'content'", "seq"); content = tagged.GetObject(); } } public ContentInfo( DerObjectIdentifier contentType, Asn1Encodable content) { this.contentType = contentType; this.content = content; } public DerObjectIdentifier ContentType { get { return contentType; } } public Asn1Encodable Content { get { return content; } } /** * Produce an object suitable for an Asn1OutputStream. *
* ContentInfo ::= Sequence { * contentType ContentType, * content * [0] EXPLICIT ANY DEFINED BY contentType OPTIONAL } **/ public override Asn1Object ToAsn1Object() { Asn1EncodableVector v = new Asn1EncodableVector(contentType); if (content != null) { v.Add(new BerTaggedObject(0, content)); } return new BerSequence(v); } } } #pragma warning restore #endif