package org.ripple.bouncycastle.jcajce;
import javax.crypto.interfaces.PBEKey;
import org.ripple.bouncycastle.util.Arrays;
public class PKCS12KeyWithParameters
extends PKCS12Key implements PBEKey
{
private final byte[] salt;
private final int iterationCount;
/**
* Basic constructor for a password based key with generation parameters.
*
* @param password password to use.
* @param salt salt for generation algorithm
* @param iterationCount iteration count for generation algorithm.
*/
public PKCS12KeyWithParameters(char[] password, byte[] salt, int iterationCount)
{
super(password);
this.salt = Arrays.clone(salt);
this.iterationCount = iterationCount;
}
/**
* Basic constructor for a password based key with generation parameters, specifying the wrong conversion for
* zero length passwords.
*
* @param password password to use.
* @param salt salt for generation algorithm
* @param iterationCount iteration count for generation algorithm.
* @param useWrongZeroLengthConversion use the incorrect encoding approach (add pad bytes)
*/
public PKCS12KeyWithParameters(char[] password, boolean useWrongZeroLengthConversion, byte[] salt, int iterationCount)
{
super(password, useWrongZeroLengthConversion);
this.salt = Arrays.clone(salt);
this.iterationCount = iterationCount;
}
public byte[] getSalt()
{
return salt;
}
public int getIterationCount()
{
return iterationCount;
}
}