blob: fced06eafffd863647526c5eb7caac0a4d53a408 [file] [log] [blame]
package org.bouncycastle.crypto.signers;
import java.math.BigInteger;
import java.security.SecureRandom;
/**
* Interface define calculators of K values for DSA/ECDSA.
*/
public interface DSAKCalculator
{
/**
* Return true if this calculator is deterministic, false otherwise.
*
* @return true if deterministic, otherwise false.
*/
boolean isDeterministic();
/**
* Non-deterministic initialiser.
*
* @param n the order of the DSA group.
* @param random a source of randomness.
*/
void init(BigInteger n, SecureRandom random);
/**
* Deterministic initialiser.
*
* @param n the order of the DSA group.
* @param d the DSA private value.
* @param message the message being signed.
*/
void init(BigInteger n, BigInteger d, byte[] message);
/**
* Return the next valid value of K.
*
* @return a K value.
*/
BigInteger nextK();
}