All Downloads are FREE. Search and download functionalities are using the official Maven repository.

org.bouncycastle.openpgp.operator.PBESecretKeyEncryptor Maven / Gradle / Ivy

Go to download

The Bouncy Castle Java API for handling the OpenPGP protocol. This jar contains the OpenPGP API for JDK 1.5 to JDK 1.8. 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.operator;

import java.security.SecureRandom;

import org.bouncycastle.bcpg.S2K;
import org.bouncycastle.openpgp.PGPException;

/**
 * Class responsible for encrypting secret key material or data packets using a passphrase.
 * 

* RFC9580 recommends the following S2K specifiers + usages: *

* * * * * * * * * * * * * * * * * * * * *
S2K SpecifierS2K UsageNote
{@link S2K#ARGON_2}{@link org.bouncycastle.bcpg.SecretKeyPacket#USAGE_AEAD}RECOMMENDED; Argon2 MUST be used with AEAD
{@link S2K#SALTED_AND_ITERATED}{@link org.bouncycastle.bcpg.SecretKeyPacket#USAGE_SHA1}MAY be used if Argon2 is not available; Take care to use high octet count + strong passphrase
none{@link org.bouncycastle.bcpg.SecretKeyPacket#USAGE_NONE}Unprotected
*

* Additionally, implementations MAY use the following combinations with caution: *

* * * * * * * * * * * * * * * *
S2K SpecifierS2K UsageNote
{@link S2K#SALTED_AND_ITERATED}{@link org.bouncycastle.bcpg.SecretKeyPacket#USAGE_AEAD}Does not provide memory hardness
{@link S2K#SIMPLE}{@link org.bouncycastle.bcpg.SecretKeyPacket#USAGE_SHA1}Only for reading secret keys in backwards compatibility mode
*/ public abstract class PBESecretKeyEncryptor { protected int encAlgorithm; protected int aeadAlgorithm; protected char[] passPhrase; protected PGPDigestCalculator s2kDigestCalculator; protected int s2kCount; protected S2K s2k; protected SecureRandom random; protected PBESecretKeyEncryptor(int encAlgorithm, int aeadAlgorithm, S2K.Argon2Params argon2Params, SecureRandom random, char[] passPhrase) { this.encAlgorithm = encAlgorithm; this.aeadAlgorithm = aeadAlgorithm; this.passPhrase = passPhrase; this.s2k = S2K.argon2S2K(argon2Params); this.random = random; } protected PBESecretKeyEncryptor(int encAlgorithm, PGPDigestCalculator s2kDigestCalculator, SecureRandom random, char[] passPhrase) { this(encAlgorithm, s2kDigestCalculator, 0x60, random, passPhrase); } protected PBESecretKeyEncryptor(int encAlgorithm, PGPDigestCalculator s2kDigestCalculator, int s2kCount, SecureRandom random, char[] passPhrase) { this.encAlgorithm = encAlgorithm; this.passPhrase = passPhrase; this.random = random; this.s2kDigestCalculator = s2kDigestCalculator; if (s2kCount < 0 || s2kCount > 0xff) { throw new IllegalArgumentException("s2kCount value outside of range 0 to 255."); } this.s2kCount = s2kCount; } public int getAlgorithm() { return encAlgorithm; } public int getAeadAlgorithm() { return aeadAlgorithm; } public int getHashAlgorithm() { if (s2kDigestCalculator != null) { return s2kDigestCalculator.getAlgorithm(); } return -1; } public byte[] getKey() throws PGPException { return PGPUtil.makeKeyFromPassPhrase(s2kDigestCalculator, encAlgorithm, s2k, passPhrase); } public S2K getS2K() { return s2k; } /** * Key encryption method invoked for V4 keys and greater. * * @param keyData raw key data * @param keyOff offset into raw key data * @param keyLen length of key data to use. * @return an encryption of the passed in keyData. * @throws PGPException on error in the underlying encryption process. */ public byte[] encryptKeyData(byte[] keyData, int keyOff, int keyLen) throws PGPException { if (s2k == null) { byte[] iv = new byte[8]; random.nextBytes(iv); s2k = new S2K(s2kDigestCalculator.getAlgorithm(), iv, s2kCount); } return encryptKeyData(getKey(), keyData, keyOff, keyLen); } public abstract byte[] encryptKeyData(byte[] key, byte[] keyData, int keyOff, int keyLen) throws PGPException; /** * Encrypt the passed in keyData using the key and the iv provided. *

* This method is only used for processing version 3 keys. *

*/ public byte[] encryptKeyData(byte[] key, byte[] iv, byte[] keyData, int keyOff, int keyLen) throws PGPException { throw new PGPException("encryption of version 3 keys not supported."); } public abstract byte[] getCipherIV(); }




© 2015 - 2025 Weber Informatics LLC | Privacy Policy