PublicKeyPacket
using Org.BouncyCastle.Utilities.Date;
using System;
using System.IO;
namespace Org.BouncyCastle.Bcpg
{
public class PublicKeyPacket : ContainedPacket
{
private int version;
private long time;
private int validDays;
private PublicKeyAlgorithmTag algorithm;
private IBcpgKey key;
public virtual int Version => version;
public virtual PublicKeyAlgorithmTag Algorithm => algorithm;
public virtual int ValidDays => validDays;
public virtual IBcpgKey Key => key;
internal PublicKeyPacket(BcpgInputStream bcpgIn)
{
version = bcpgIn.ReadByte();
time = (uint)((bcpgIn.ReadByte() << 24) | (bcpgIn.ReadByte() << 16) | (bcpgIn.ReadByte() << 8) | bcpgIn.ReadByte());
if (version <= 3)
validDays = ((bcpgIn.ReadByte() << 8) | bcpgIn.ReadByte());
algorithm = (PublicKeyAlgorithmTag)bcpgIn.ReadByte();
PublicKeyAlgorithmTag publicKeyAlgorithmTag = algorithm;
if ((uint)(publicKeyAlgorithmTag - 1) > 2) {
switch (publicKeyAlgorithmTag) {
case PublicKeyAlgorithmTag.Dsa:
key = new DsaPublicBcpgKey(bcpgIn);
break;
case PublicKeyAlgorithmTag.ElGamalEncrypt:
case PublicKeyAlgorithmTag.ElGamalGeneral:
key = new ElGamalPublicBcpgKey(bcpgIn);
break;
case PublicKeyAlgorithmTag.ECDH:
key = new ECDHPublicBcpgKey(bcpgIn);
break;
case PublicKeyAlgorithmTag.ECDsa:
key = new ECDsaPublicBcpgKey(bcpgIn);
break;
case PublicKeyAlgorithmTag.EdDsa:
key = new EdDsaPublicBcpgKey(bcpgIn);
break;
default:
throw new IOException("unknown PGP public key algorithm encountered");
}
} else
key = new RsaPublicBcpgKey(bcpgIn);
}
public PublicKeyPacket(PublicKeyAlgorithmTag algorithm, DateTime time, IBcpgKey key)
{
version = 4;
this.time = DateTimeUtilities.DateTimeToUnixMs(time) / 1000;
this.algorithm = algorithm;
this.key = key;
}
public virtual DateTime GetTime()
{
return DateTimeUtilities.UnixMsToDateTime(time * 1000);
}
public virtual byte[] GetEncodedContents()
{
MemoryStream memoryStream = new MemoryStream();
using (BcpgOutputStream bcpgOutputStream = new BcpgOutputStream(memoryStream)) {
bcpgOutputStream.WriteByte((byte)version);
bcpgOutputStream.WriteInt((int)time);
if (version <= 3)
bcpgOutputStream.WriteShort((short)validDays);
bcpgOutputStream.WriteByte((byte)algorithm);
bcpgOutputStream.WriteObject((BcpgObject)key);
}
return memoryStream.ToArray();
}
public override void Encode(BcpgOutputStream bcpgOut)
{
bcpgOut.WritePacket(PacketTag.PublicKey, GetEncodedContents());
}
}
}