org.bouncycastle.openpgp.PGPPrivateKey Maven / Gradle / Ivy
Go to download
Show more of this group Show more artifacts with this name
Show all versions of bcpg-jdk14 Show documentation
Show all versions of bcpg-jdk14 Show documentation
The Bouncy Castle Java API for handling the OpenPGP protocol. This jar contains the OpenPGP API for JDK 1.4. The APIs can be used in conjunction with a JCE/JCA provider such as the one provided with the Bouncy Castle Cryptography APIs.
The newest version!
package org.bouncycastle.openpgp;
import org.bouncycastle.bcpg.BCPGKey;
import org.bouncycastle.bcpg.KeyIdentifier;
import org.bouncycastle.bcpg.PublicKeyPacket;
import org.bouncycastle.openpgp.operator.KeyFingerPrintCalculator;
/**
* general class to contain a private key for use with other openPGP
* objects.
*/
public class PGPPrivateKey
{
private long keyID;
private PublicKeyPacket publicKeyPacket;
private BCPGKey privateKeyDataPacket;
/**
* Base constructor.
*
* Create a PGPPrivateKey from a keyID and the associated public/private data packets needed
* to fully describe it.
*
* @param keyID keyID associated with the public key.
* @param publicKeyPacket the public key data packet to be associated with this private key.
* @param privateKeyDataPacket the private key data packet to be associate with this private key.
*/
public PGPPrivateKey(
long keyID,
PublicKeyPacket publicKeyPacket,
BCPGKey privateKeyDataPacket)
{
this.keyID = keyID;
this.publicKeyPacket = publicKeyPacket;
this.privateKeyDataPacket = privateKeyDataPacket;
}
/**
* Return the keyID associated with the contained private key.
*
* @return long
*/
public long getKeyID()
{
return keyID;
}
public KeyIdentifier getKeyIdentifier(KeyFingerPrintCalculator fingerprintCalculator)
throws PGPException
{
byte[] fingerprint = fingerprintCalculator.calculateFingerprint(publicKeyPacket);
return new KeyIdentifier(fingerprint, PublicKeyPacket.getKeyID(publicKeyPacket, fingerprint));
}
/**
* Return the public key packet associated with this private key, if available.
*
* @return associated public key packet, null otherwise.
*/
public PublicKeyPacket getPublicKeyPacket()
{
return publicKeyPacket;
}
/**
* Return the private key packet associated with this private key, if available.
*
* @return associated private key packet, null otherwise.
*/
public BCPGKey getPrivateKeyDataPacket()
{
return privateKeyDataPacket;
}
}