You can not select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
142 lines
3.8 KiB
142 lines
3.8 KiB
1 year ago
|
#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
|