123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141 |
- #if !BESTHTTP_DISABLE_ALTERNATE_SSL && (!UNITY_WEBGL || UNITY_EDITOR)
- #pragma warning disable
- using System;
- using BestHTTP.SecureProtocol.Org.BouncyCastle.Utilities;
- namespace BestHTTP.SecureProtocol.Org.BouncyCastle.Asn1.Cms
- {
- public class RecipientKeyIdentifier
- : Asn1Encodable
- {
- private Asn1OctetString subjectKeyIdentifier;
- private DerGeneralizedTime date;
- private OtherKeyAttribute other;
- public RecipientKeyIdentifier(
- Asn1OctetString subjectKeyIdentifier,
- DerGeneralizedTime date,
- OtherKeyAttribute other)
- {
- this.subjectKeyIdentifier = subjectKeyIdentifier;
- this.date = date;
- this.other = other;
- }
-
- public RecipientKeyIdentifier(
- byte[] subjectKeyIdentifier)
- : this(subjectKeyIdentifier, null, null)
- {
- }
- public RecipientKeyIdentifier(
- byte[] subjectKeyIdentifier,
- DerGeneralizedTime date,
- OtherKeyAttribute other)
- {
- this.subjectKeyIdentifier = new DerOctetString(subjectKeyIdentifier);
- this.date = date;
- this.other = other;
- }
- public RecipientKeyIdentifier(
- Asn1Sequence seq)
- {
- subjectKeyIdentifier = Asn1OctetString.GetInstance(
- seq[0]);
- switch(seq.Count)
- {
- case 1:
- break;
- case 2:
- if (seq[1] is DerGeneralizedTime)
- {
- date = (DerGeneralizedTime) seq[1];
- }
- else
- {
- other = OtherKeyAttribute.GetInstance(seq[2]);
- }
- break;
- case 3:
- date = (DerGeneralizedTime) seq[1];
- other = OtherKeyAttribute.GetInstance(seq[2]);
- break;
- default:
- throw new ArgumentException("Invalid RecipientKeyIdentifier");
- }
- }
- /**
- * return a RecipientKeyIdentifier object from a tagged object.
- *
- * @param _ato the tagged object holding the object we want.
- * @param _explicit true if the object is meant to be explicitly
- * tagged false otherwise.
- * @exception ArgumentException if the object held by the
- * tagged object cannot be converted.
- */
- public static RecipientKeyIdentifier GetInstance(
- Asn1TaggedObject ato,
- bool explicitly)
- {
- return GetInstance(Asn1Sequence.GetInstance(ato, explicitly));
- }
- /**
- * return a RecipientKeyIdentifier object from the given object.
- *
- * @param _obj the object we want converted.
- * @exception ArgumentException if the object cannot be converted.
- */
- public static RecipientKeyIdentifier GetInstance(
- object obj)
- {
- if (obj == null || obj is RecipientKeyIdentifier)
- return (RecipientKeyIdentifier) obj;
- if (obj is Asn1Sequence)
- return new RecipientKeyIdentifier((Asn1Sequence) obj);
- throw new ArgumentException("Invalid RecipientKeyIdentifier: " + BestHTTP.SecureProtocol.Org.BouncyCastle.Utilities.Platform.GetTypeName(obj));
- }
- public Asn1OctetString SubjectKeyIdentifier
- {
- get { return subjectKeyIdentifier; }
- }
- public DerGeneralizedTime Date
- {
- get { return date; }
- }
- public OtherKeyAttribute OtherKeyAttribute
- {
- get { return other; }
- }
- /**
- * Produce an object suitable for an Asn1OutputStream.
- * <pre>
- * RecipientKeyIdentifier ::= Sequence {
- * subjectKeyIdentifier SubjectKeyIdentifier,
- * date GeneralizedTime OPTIONAL,
- * other OtherKeyAttribute OPTIONAL
- * }
- *
- * SubjectKeyIdentifier ::= OCTET STRING
- * </pre>
- */
- public override Asn1Object ToAsn1Object()
- {
- Asn1EncodableVector v = new Asn1EncodableVector(subjectKeyIdentifier);
- v.AddOptional(date, other);
- return new DerSequence(v);
- }
- }
- }
- #pragma warning restore
- #endif
|