![JAR search and dependency download from the Maven repository](/logo.png)
org.bouncycastle.util.test.FixedEntropySourceProvider Maven / Gradle / Ivy
Go to download
Show more of this group Show more artifacts with this name
Show all versions of bc-fips-debug Show documentation
Show all versions of bc-fips-debug Show documentation
The FIPS 140-2 Bouncy Castle Crypto package is a Java implementation of cryptographic algorithms certified to FIPS 140-2 level 1. This jar contains the debug version JCE provider and low-level API for the BC-FJA version 1.0.2.3, FIPS Certificate #3514. Please note the debug jar is not certified.
package org.bouncycastle.util.test;
import org.bouncycastle.crypto.EntropySource;
import org.bouncycastle.crypto.EntropySourceProvider;
/**
* An "entropy" provider which returns pre-defined data on request.
*/
public class FixedEntropySourceProvider
implements EntropySourceProvider
{
private final byte[] data;
private final boolean isPredictionResistant;
/**
* Base constructor.
*
* @param data the data that will be returned by EntropySources created by this provider.
* @param isPredictionResistant true if the EntropySource should be marked as prediction resistant, false otherwise.
*/
public FixedEntropySourceProvider(byte[] data, boolean isPredictionResistant)
{
this.data = data;
this.isPredictionResistant = isPredictionResistant;
}
/**
* Return an EntropySource based on the data provided to this object.
*
* @param bitsRequired the size of the block of entropy required.
* @return a new EntropySource.
*/
public EntropySource get(final int bitsRequired)
{
return new EntropySource()
{
boolean first = true;
int index = 0;
public boolean isPredictionResistant()
{
return isPredictionResistant;
}
public byte[] getEntropy()
{
byte[] rv = new byte[(bitsRequired + 7) / 8];
System.arraycopy(data, index, rv, 0, rv.length);
// we assume continuous testing
if (first)
{
for (int i = 0; i != rv.length; i++)
{
rv[i] ^= 0xff;
}
first = false;
}
else
{
index += (bitsRequired + 7) / 8;
}
return rv;
}
public int entropySize()
{
return bitsRequired;
}
};
}
}
© 2015 - 2025 Weber Informatics LLC | Privacy Policy