Package org.bouncycastle.crypto.modes
Class G3413CFBBlockCipher
- java.lang.Object
- 
- org.bouncycastle.crypto.StreamBlockCipher
- 
- org.bouncycastle.crypto.modes.G3413CFBBlockCipher
 
 
- 
- All Implemented Interfaces:
- BlockCipher,- StreamCipher
 
 public class G3413CFBBlockCipher extends StreamBlockCipher An implementation of the CFB mode for GOST 3412 2015 cipher. See GOST R 3413 2015
- 
- 
Constructor SummaryConstructors Constructor Description G3413CFBBlockCipher(BlockCipher cipher)Base constructor.G3413CFBBlockCipher(BlockCipher cipher, int bitBlockSize)Base constructor with specific block size.
 - 
Method SummaryAll Methods Instance Methods Concrete Methods Modifier and Type Method Description protected bytecalculateByte(byte in)java.lang.StringgetAlgorithmName()Return the name of the algorithm the cipher implements.intgetBlockSize()Return the block size for this cipher (in bytes).voidinit(boolean forEncryption, CipherParameters params)Initialise the cipher and initialisation vector R.intprocessBlock(byte[] in, int inOff, byte[] out, int outOff)Process one block of input from the array in and write it to the out array.voidreset()copy R_init into R and reset the underlying cipher.- 
Methods inherited from class org.bouncycastle.crypto.StreamBlockCiphergetUnderlyingCipher, processBytes, returnByte
 
- 
 
- 
- 
- 
Constructor Detail- 
G3413CFBBlockCipherpublic G3413CFBBlockCipher(BlockCipher cipher) Base constructor.- Parameters:
- cipher- base cipher
 
 - 
G3413CFBBlockCipherpublic G3413CFBBlockCipher(BlockCipher cipher, int bitBlockSize) Base constructor with specific block size.- Parameters:
- cipher- base cipher
- bitBlockSize- basic unit (defined as s)
 
 
- 
 - 
Method Detail- 
initpublic void init(boolean forEncryption, CipherParameters params) throws java.lang.IllegalArgumentExceptionInitialise the cipher and initialisation vector R. If an IV isn't passed as part of the parameter, the IV will be all zeros. An IV which is too short is handled in FIPS compliant fashion. R_init = IV, and R1 = R_init- Parameters:
- forEncryption- ignored because encryption and decryption are same
- params- the key and other data required by the cipher.
- Throws:
- java.lang.IllegalArgumentException
 
 - 
getAlgorithmNamepublic java.lang.String getAlgorithmName() Description copied from interface:BlockCipherReturn the name of the algorithm the cipher implements.- Returns:
- the name of the algorithm the cipher implements.
 
 - 
getBlockSizepublic int getBlockSize() Description copied from interface:BlockCipherReturn the block size for this cipher (in bytes).- Returns:
- the block size for this cipher in bytes.
 
 - 
processBlockpublic int processBlock(byte[] in, int inOff, byte[] out, int outOff) throws DataLengthException, java.lang.IllegalStateExceptionDescription copied from interface:BlockCipherProcess one block of input from the array in and write it to the out array.- Parameters:
- 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.
- Returns:
- the number of bytes processed and produced.
- Throws:
- DataLengthException- if there isn't enough data in in, or space in out.
- java.lang.IllegalStateException- if the cipher isn't initialised.
 
 - 
calculateByteprotected byte calculateByte(byte in) - Specified by:
- calculateBytein class- StreamBlockCipher
 
 - 
resetpublic void reset() copy R_init into R and reset the underlying cipher.
 
- 
 
-