blob: 4b172c8a4813a5804deaab529a28ccc3668cf30b [file] [log] [blame]
package org.bouncycastle.pqc.crypto;
import org.bouncycastle.crypto.CipherParameters;
/**
* Base interface for a PQC signing algorithm.
*/
public interface MessageSigner
{
/**
* initialise the signer for signature generation or signature
* verification.
*
* @param forSigning true if we are generating a signature, false
* otherwise.
* @param param key parameters for signature generation.
*/
public void init(boolean forSigning, CipherParameters param);
/**
* sign the passed in message (usually the output of a hash function).
*
* @param message the message to be signed.
* @return the signature of the message
*/
public byte[] generateSignature(byte[] message);
/**
* verify the message message against the signature value.
*
* @param message the message that was supposed to have been signed.
* @param signature the signature of the message
*/
public boolean verifySignature(byte[] message, byte[] signature);
}