<PackageReference Include="BouncyCastle.Cryptography" Version="2.4.0" />

KeyAgreeRecipientIdentifier

using Org.BouncyCastle.Utilities; using System; namespace Org.BouncyCastle.Asn1.Cms { public class KeyAgreeRecipientIdentifier : Asn1Encodable, IAsn1Choice { private readonly IssuerAndSerialNumber issuerSerial; private readonly RecipientKeyIdentifier rKeyID; public IssuerAndSerialNumber IssuerAndSerialNumber => issuerSerial; public RecipientKeyIdentifier RKeyID => rKeyID; public static KeyAgreeRecipientIdentifier GetInstance(object obj) { if (obj == null) return null; KeyAgreeRecipientIdentifier keyAgreeRecipientIdentifier = obj as KeyAgreeRecipientIdentifier; if (keyAgreeRecipientIdentifier != null) return keyAgreeRecipientIdentifier; IssuerAndSerialNumber issuerAndSerialNumber = obj as IssuerAndSerialNumber; if (issuerAndSerialNumber != null) return new KeyAgreeRecipientIdentifier(issuerAndSerialNumber); Asn1Sequence asn1Sequence = obj as Asn1Sequence; if (asn1Sequence != null) return new KeyAgreeRecipientIdentifier(IssuerAndSerialNumber.GetInstance(asn1Sequence)); Asn1TaggedObject asn1TaggedObject = obj as Asn1TaggedObject; if (asn1TaggedObject != null && asn1TaggedObject.HasContextTag(0)) return new KeyAgreeRecipientIdentifier(RecipientKeyIdentifier.GetInstance(asn1TaggedObject, false)); throw new ArgumentException("Invalid KeyAgreeRecipientIdentifier: " + Platform.GetTypeName(obj), "obj"); } public static KeyAgreeRecipientIdentifier GetInstance(Asn1TaggedObject obj, bool isExplicit) { return Asn1Utilities.GetInstanceFromChoice(obj, isExplicit, GetInstance); } public KeyAgreeRecipientIdentifier(IssuerAndSerialNumber issuerSerial) { this.issuerSerial = issuerSerial; } public KeyAgreeRecipientIdentifier(RecipientKeyIdentifier rKeyID) { this.rKeyID = rKeyID; } public override Asn1Object ToAsn1Object() { if (issuerSerial != null) return issuerSerial.ToAsn1Object(); return new DerTaggedObject(false, 0, rKeyID); } } }