123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103 |
- #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.Cms
- {
- public class KeyTransRecipientInfo
- : Asn1Encodable
- {
- private DerInteger version;
- private RecipientIdentifier rid;
- private AlgorithmIdentifier keyEncryptionAlgorithm;
- private Asn1OctetString encryptedKey;
- public KeyTransRecipientInfo(
- RecipientIdentifier rid,
- AlgorithmIdentifier keyEncryptionAlgorithm,
- Asn1OctetString encryptedKey)
- {
- if (rid.ToAsn1Object() is Asn1TaggedObject)
- {
- this.version = new DerInteger(2);
- }
- else
- {
- this.version = new DerInteger(0);
- }
- this.rid = rid;
- this.keyEncryptionAlgorithm = keyEncryptionAlgorithm;
- this.encryptedKey = encryptedKey;
- }
- public KeyTransRecipientInfo(
- Asn1Sequence seq)
- {
- this.version = (DerInteger) seq[0];
- this.rid = RecipientIdentifier.GetInstance(seq[1]);
- this.keyEncryptionAlgorithm = AlgorithmIdentifier.GetInstance(seq[2]);
- this.encryptedKey = (Asn1OctetString) seq[3];
- }
- /**
- * return a KeyTransRecipientInfo object from the given object.
- *
- * @param obj the object we want converted.
- * @exception ArgumentException if the object cannot be converted.
- */
- public static KeyTransRecipientInfo GetInstance(
- object obj)
- {
- if (obj == null || obj is KeyTransRecipientInfo)
- return (KeyTransRecipientInfo) obj;
- if(obj is Asn1Sequence)
- return new KeyTransRecipientInfo((Asn1Sequence) obj);
- throw new ArgumentException(
- "Illegal object in KeyTransRecipientInfo: " + BestHTTP.SecureProtocol.Org.BouncyCastle.Utilities.Platform.GetTypeName(obj));
- }
- public DerInteger Version
- {
- get { return version; }
- }
- public RecipientIdentifier RecipientIdentifier
- {
- get { return rid; }
- }
- public AlgorithmIdentifier KeyEncryptionAlgorithm
- {
- get { return keyEncryptionAlgorithm; }
- }
- public Asn1OctetString EncryptedKey
- {
- get { return encryptedKey; }
- }
- /**
- * Produce an object suitable for an Asn1OutputStream.
- * <pre>
- * KeyTransRecipientInfo ::= Sequence {
- * version CMSVersion, -- always set to 0 or 2
- * rid RecipientIdentifier,
- * keyEncryptionAlgorithm KeyEncryptionAlgorithmIdentifier,
- * encryptedKey EncryptedKey
- * }
- * </pre>
- */
- public override Asn1Object ToAsn1Object()
- {
- return new DerSequence(version, rid, keyEncryptionAlgorithm, encryptedKey);
- }
- }
- }
- #pragma warning restore
- #endif
|