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, returnByte
getMultiBlockSize, processBlocks
clone, equals, finalize, getClass, hashCode, notify, notifyAll, toString, wait, wait, wait
getUnderlyingCipher
getMultiBlockSize, processBlocks
returnByte
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
BlockCipher
init
in interface BlockCipher
init
in interface StreamCipher
forEncryption
- 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()
BlockCipher
getAlgorithmName
in interface BlockCipher
getAlgorithmName
in interface StreamCipher
public int getBlockSize()
BlockCipher
getBlockSize
in interface BlockCipher
public int processBlock(byte[] in, int inOff, byte[] out, int outOff) throws DataLengthException, java.lang.IllegalStateException
BlockCipher
processBlock
in interface BlockCipher
in
- 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
StreamCipher
processBytes
in interface StreamCipher
processBytes
in class StreamBlockCipher
in
- 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 StreamBlockCipher
DataLengthException
java.lang.IllegalStateException
public void reset()
BlockCipher
reset
in interface BlockCipher
reset
in interface StreamCipher
public long skip(long numberOfBytes)
SkippingCipher
skip
in interface SkippingCipher
numberOfBytes
- the number of bytes to skip (positive forward, negative backwards).public long seekTo(long position)
SkippingCipher
seekTo
in interface SkippingCipher
position
- the number of bytes in to set the cipher state to.public long getPosition()
SkippingCipher
getPosition
in interface SkippingCipher