Package org.bouncycastle.crypto.modes
Class CTSBlockCipher
- java.lang.Object
 - 
- org.bouncycastle.crypto.BufferedBlockCipher
 - 
- org.bouncycastle.crypto.modes.CTSBlockCipher
 
 
 
- 
public class CTSBlockCipher extends BufferedBlockCipher
A Cipher Text Stealing (CTS) mode cipher. CTS allows block ciphers to be used to produce cipher text which is the same length as the plain text. 
- 
- 
Field Summary
- 
Fields inherited from class org.bouncycastle.crypto.BufferedBlockCipher
buf, bufOff, cipher, forEncryption, partialBlockOkay, pgpCFB 
 - 
 
- 
Constructor Summary
Constructors Constructor Description CTSBlockCipher(BlockCipher cipher)Create a buffered block cipher that uses Cipher Text Stealing 
- 
Method Summary
All Methods Instance Methods Concrete Methods Modifier and Type Method Description intdoFinal(byte[] out, int outOff)Process the last block in the buffer.intgetOutputSize(int len)return the size of the output buffer required for an update plus a doFinal with an input of len bytes.intgetUpdateOutputSize(int len)return the size of the output buffer required for an update an input of len bytes.intprocessByte(byte in, byte[] out, int outOff)process a single byte, producing an output block if necessary.intprocessBytes(byte[] in, int inOff, int len, byte[] out, int outOff)process an array of bytes, producing output if necessary.- 
Methods inherited from class org.bouncycastle.crypto.BufferedBlockCipher
getBlockSize, getUnderlyingCipher, init, reset 
 - 
 
 - 
 
- 
- 
Constructor Detail
- 
CTSBlockCipher
public CTSBlockCipher(BlockCipher cipher)
Create a buffered block cipher that uses Cipher Text Stealing- Parameters:
 cipher- the underlying block cipher this buffering object wraps.
 
 - 
 
- 
Method Detail
- 
getUpdateOutputSize
public int getUpdateOutputSize(int len)
return the size of the output buffer required for an update an input of len bytes.- Overrides:
 getUpdateOutputSizein classBufferedBlockCipher- Parameters:
 len- the length of the input.- Returns:
 - the space required to accommodate a call to update with len bytes of input.
 
 
- 
getOutputSize
public int getOutputSize(int len)
return the size of the output buffer required for an update plus a doFinal with an input of len bytes.- Overrides:
 getOutputSizein classBufferedBlockCipher- Parameters:
 len- the length of the input.- Returns:
 - the space required to accommodate a call to update and doFinal with len bytes of input.
 
 
- 
processByte
public int processByte(byte in, byte[] out, int outOff) throws DataLengthException, java.lang.IllegalStateExceptionprocess a single byte, producing an output block if necessary.- Overrides:
 processBytein classBufferedBlockCipher- Parameters:
 in- the input byte.out- the space for any output that might be produced.outOff- the offset from which the output will be copied.- Returns:
 - the number of output bytes copied to out.
 - Throws:
 DataLengthException- if there isn't enough space in out.java.lang.IllegalStateException- if the cipher isn't initialised.
 
- 
processBytes
public int processBytes(byte[] in, int inOff, int len, byte[] out, int outOff) throws DataLengthException, java.lang.IllegalStateExceptionprocess an array of bytes, producing output if necessary.- Overrides:
 processBytesin classBufferedBlockCipher- Parameters:
 in- the input byte array.inOff- the offset at which the input data starts.len- the number of bytes to be copied out of the input array.out- the space for any output that might be produced.outOff- the offset from which the output will be copied.- Returns:
 - the number of output bytes copied to out.
 - Throws:
 DataLengthException- if there isn't enough space in out.java.lang.IllegalStateException- if the cipher isn't initialised.
 
- 
doFinal
public int doFinal(byte[] out, int outOff) throws DataLengthException, java.lang.IllegalStateException, InvalidCipherTextExceptionProcess the last block in the buffer.- Overrides:
 doFinalin classBufferedBlockCipher- Parameters:
 out- the array the block currently being held is copied into.outOff- the offset at which the copying starts.- Returns:
 - the number of output bytes copied to out.
 - Throws:
 DataLengthException- if there is insufficient space in out for the output.java.lang.IllegalStateException- if the underlying cipher is not initialised.InvalidCipherTextException- if cipher text decrypts wrongly (in case the exception will never get thrown).
 
 - 
 
 -