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.
119 lines
3.2 KiB
119 lines
3.2 KiB
#if !BESTHTTP_DISABLE_ALTERNATE_SSL && (!UNITY_WEBGL || UNITY_EDITOR) |
|
#pragma warning disable |
|
using System; |
|
using System.Collections; |
|
using System.IO; |
|
|
|
namespace BestHTTP.SecureProtocol.Org.BouncyCastle.Asn1.X509 |
|
{ |
|
/** |
|
* The object that contains the public key stored in a certficate. |
|
* <p> |
|
* The GetEncoded() method in the public keys in the JCE produces a DER |
|
* encoded one of these.</p> |
|
*/ |
|
public class SubjectPublicKeyInfo |
|
: Asn1Encodable |
|
{ |
|
private readonly AlgorithmIdentifier algID; |
|
private readonly DerBitString keyData; |
|
|
|
public static SubjectPublicKeyInfo GetInstance( |
|
Asn1TaggedObject obj, |
|
bool explicitly) |
|
{ |
|
return GetInstance(Asn1Sequence.GetInstance(obj, explicitly)); |
|
} |
|
|
|
public static SubjectPublicKeyInfo GetInstance( |
|
object obj) |
|
{ |
|
if (obj is SubjectPublicKeyInfo) |
|
return (SubjectPublicKeyInfo) obj; |
|
|
|
if (obj != null) |
|
return new SubjectPublicKeyInfo(Asn1Sequence.GetInstance(obj)); |
|
|
|
return null; |
|
} |
|
|
|
public SubjectPublicKeyInfo( |
|
AlgorithmIdentifier algID, |
|
Asn1Encodable publicKey) |
|
{ |
|
this.keyData = new DerBitString(publicKey); |
|
this.algID = algID; |
|
} |
|
|
|
public SubjectPublicKeyInfo( |
|
AlgorithmIdentifier algID, |
|
byte[] publicKey) |
|
{ |
|
this.keyData = new DerBitString(publicKey); |
|
this.algID = algID; |
|
} |
|
|
|
private SubjectPublicKeyInfo( |
|
Asn1Sequence seq) |
|
{ |
|
if (seq.Count != 2) |
|
throw new ArgumentException("Bad sequence size: " + seq.Count, "seq"); |
|
|
|
this.algID = AlgorithmIdentifier.GetInstance(seq[0]); |
|
this.keyData = DerBitString.GetInstance(seq[1]); |
|
} |
|
|
|
public AlgorithmIdentifier AlgorithmID |
|
{ |
|
get { return algID; } |
|
} |
|
|
|
/** |
|
* for when the public key is an encoded object - if the bitstring |
|
* can't be decoded this routine raises an IOException. |
|
* |
|
* @exception IOException - if the bit string doesn't represent a Der |
|
* encoded object. |
|
*/ |
|
public Asn1Object ParsePublicKey() |
|
{ |
|
return Asn1Object.FromByteArray(keyData.GetOctets()); |
|
} |
|
|
|
/** |
|
* for when the public key is an encoded object - if the bitstring |
|
* can't be decoded this routine raises an IOException. |
|
* |
|
* @exception IOException - if the bit string doesn't represent a Der |
|
* encoded object. |
|
*/ |
|
|
|
public Asn1Object GetPublicKey() |
|
{ |
|
return Asn1Object.FromByteArray(keyData.GetOctets()); |
|
} |
|
|
|
/** |
|
* for when the public key is raw bits... |
|
*/ |
|
public DerBitString PublicKeyData |
|
{ |
|
get { return keyData; } |
|
} |
|
|
|
/** |
|
* Produce an object suitable for an Asn1OutputStream. |
|
* <pre> |
|
* SubjectPublicKeyInfo ::= Sequence { |
|
* algorithm AlgorithmIdentifier, |
|
* publicKey BIT STRING } |
|
* </pre> |
|
*/ |
|
public override Asn1Object ToAsn1Object() |
|
{ |
|
return new DerSequence(algID, keyData); |
|
} |
|
} |
|
} |
|
#pragma warning restore |
|
#endif
|
|
|