public class SICBlockCipher extends StreamBlockCipher implements CTRModeCipher
| Constructor and Description |
|---|
SICBlockCipher(BlockCipher c)
Deprecated.
use newInstance() method.
|
| Modifier and Type | Method and Description |
|---|---|
protected byte |
calculateByte(byte in) |
java.lang.String |
getAlgorithmName()
Return the name of the algorithm the cipher implements.
|
int |
getBlockSize()
Return the block size for this cipher (in bytes).
|
long |
getPosition()
Return the current "position" of the cipher
|
void |
init(boolean forEncryption,
CipherParameters params)
Initialise the cipher.
|
static CTRModeCipher |
newInstance(BlockCipher cipher)
Return a new SIC/CTR mode cipher based on the passed in base cipher
|
int |
processBlock(byte[] in,
int inOff,
byte[] out,
int outOff)
Process one block of input from the array in and write it to
the out array.
|
int |
processBytes(byte[] in,
int inOff,
int len,
byte[] out,
int outOff)
process a block of bytes from in putting the result into out.
|
void |
reset()
Reset the cipher.
|
long |
seekTo(long position)
Reset the cipher and then skip forward to a given position.
|
long |
skip(long numberOfBytes)
Skip numberOfBytes forwards, or backwards.
|
getUnderlyingCipher, returnBytegetMultiBlockSize, processBlocksclone, equals, finalize, getClass, hashCode, notify, notifyAll, toString, wait, wait, waitgetUnderlyingCiphergetMultiBlockSize, processBlocksreturnByte@Deprecated public SICBlockCipher(BlockCipher c)
c - the block cipher to be used.public static CTRModeCipher newInstance(BlockCipher cipher)
cipher - the base cipher for the SIC/CTR mode.public void init(boolean forEncryption,
CipherParameters params)
throws java.lang.IllegalArgumentException
BlockCipherinit in interface BlockCipherinit in interface StreamCipherforEncryption - if true the cipher is initialised for
encryption, if false for decryption.params - the key and other data required by the cipher.java.lang.IllegalArgumentException - if the params argument is
inappropriate.public java.lang.String getAlgorithmName()
BlockCiphergetAlgorithmName in interface BlockCiphergetAlgorithmName in interface StreamCipherpublic int getBlockSize()
BlockCiphergetBlockSize in interface BlockCipherpublic int processBlock(byte[] in,
int inOff,
byte[] out,
int outOff)
throws DataLengthException,
java.lang.IllegalStateException
BlockCipherprocessBlock in interface BlockCipherin - the array containing the input data.inOff - offset into the in array the data starts at.out - the array the output data will be copied into.outOff - the offset into the out array the output will start at.DataLengthException - if there isn't enough data in input , or
space in out.java.lang.IllegalStateException - if the cipher isn't initialised.public int processBytes(byte[] in,
int inOff,
int len,
byte[] out,
int outOff)
throws DataLengthException
StreamCipherprocessBytes in interface StreamCipherprocessBytes in class StreamBlockCipherin - the input byte array.inOff - the offset into the in array where the data to be processed starts.len - the number of bytes to be processed.out - the output buffer the processed bytes go into.outOff - the offset into the output byte array the processed data starts at.DataLengthException - if the output buffer is too small.protected byte calculateByte(byte in)
throws DataLengthException,
java.lang.IllegalStateException
calculateByte in class StreamBlockCipherDataLengthExceptionjava.lang.IllegalStateExceptionpublic void reset()
BlockCipherreset in interface BlockCipherreset in interface StreamCipherpublic long skip(long numberOfBytes)
SkippingCipherskip in interface SkippingCiphernumberOfBytes - the number of bytes to skip (positive forward, negative backwards).public long seekTo(long position)
SkippingCipherseekTo in interface SkippingCipherposition - the number of bytes in to set the cipher state to.public long getPosition()
SkippingCiphergetPosition in interface SkippingCipher