12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970 |
- #if !BESTHTTP_DISABLE_ALTERNATE_SSL && (!UNITY_WEBGL || UNITY_EDITOR)
- #pragma warning disable
- using System;
- using Best.HTTP.SecureProtocol.Org.BouncyCastle.Math;
- namespace Best.HTTP.SecureProtocol.Org.BouncyCastle.Bcpg
- {
- /// <remarks>Base class for an RSA public key.</remarks>
- public class RsaPublicBcpgKey
- : BcpgObject, IBcpgKey
- {
- private readonly MPInteger n, e;
- /// <summary>Construct an RSA public key from the passed in stream.</summary>
- public RsaPublicBcpgKey(
- BcpgInputStream bcpgIn)
- {
- this.n = new MPInteger(bcpgIn);
- this.e = new MPInteger(bcpgIn);
- }
- /// <param name="n">The modulus.</param>
- /// <param name="e">The public exponent.</param>
- public RsaPublicBcpgKey(
- BigInteger n,
- BigInteger e)
- {
- this.n = new MPInteger(n);
- this.e = new MPInteger(e);
- }
- public BigInteger PublicExponent
- {
- get { return e.Value; }
- }
- public BigInteger Modulus
- {
- get { return n.Value; }
- }
- /// <summary>The format, as a string, always "PGP".</summary>
- public string Format
- {
- get { return "PGP"; }
- }
- /// <summary>Return the standard PGP encoding of the key.</summary>
- public override byte[] GetEncoded()
- {
- try
- {
- return base.GetEncoded();
- }
- catch (Exception)
- {
- return null;
- }
- }
- public override void Encode(
- BcpgOutputStream bcpgOut)
- {
- bcpgOut.WriteObjects(n, e);
- }
- }
- }
- #pragma warning restore
- #endif
|