org.bouncycastle.crypto.fips.FixedEntropySourceProvider Maven / Gradle / Ivy
Go to download
Show more of this group Show more artifacts with this name
Show all versions of bc-fips Show documentation
Show all versions of bc-fips Show documentation
The FIPS 140-3 Bouncy Castle Crypto package is a Java implementation of cryptographic algorithms certified to FIPS 140-3 level 1. This jar contains JCE provider and low-level API for the BC-FJA version 2.0.0, FIPS Certificate #4743. Please see certificate for certified platform details.
package org.bouncycastle.crypto.fips;
import org.bouncycastle.crypto.EntropySource;
import org.bouncycastle.crypto.EntropySourceProvider;
class FixedEntropySourceProvider
implements EntropySourceProvider
{
private final byte[] data;
private final boolean isPredictionResistant;
protected FixedEntropySourceProvider(byte[] data, boolean isPredictionResistant)
{
this.data = data;
this.isPredictionResistant = isPredictionResistant;
}
public EntropySource get(final int bitsRequired)
{
return new EntropySource()
{
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);
index += (bitsRequired + 7) / 8;
return rv;
}
public int entropySize()
{
return bitsRequired;
}
};
}
}