For the latest news and information visit
The GNU Crypto project

gnu.crypto.cipher
Class Twofish

java.lang.Object
  extended by gnu.crypto.cipher.BaseCipher
      extended by gnu.crypto.cipher.Twofish
All Implemented Interfaces:
IBlockCipher, IBlockCipherSpi, Cloneable

public final class Twofish
extends BaseCipher

Twofish is a balanced 128-bit Feistel cipher, consisting of 16 rounds. In each round, a 64-bit S-box value is computed from 64 bits of the block, and this value is xored into the other half of the block. The two half-blocks are then exchanged, and the next round begins. Before the first round, all input bits are xored with key-dependent "whitening" subkeys, and after the final round the output bits are xored with other key-dependent whitening subkeys; these subkeys are not used anywhere else in the algorithm.

Twofish is designed by Bruce Schneier, Doug Whiting, John Kelsey, Chris Hall, David Wagner and Niels Ferguson.

References:

  1. Twofish: A 128-bit Block Cipher.

Version:
$Revision: 1.10 $

Field Summary
 
Fields inherited from class gnu.crypto.cipher.BaseCipher
currentBlockSize, currentKey, defaultBlockSize, defaultKeySize, lock, name
 
Fields inherited from interface gnu.crypto.cipher.IBlockCipher
CIPHER_BLOCK_SIZE, KEY_MATERIAL
 
Constructor Summary
Twofish()
          Trivial 0-arguments constructor.
 
Method Summary
 Iterator blockSizes()
          Returns an Iterator over the supported block sizes.
 Object clone()
          Returns a clone of this instance.
 void decrypt(byte[] in, int inOffset, byte[] out, int outOffset, Object sessionKey, int bs)
           
 void encrypt(byte[] in, int inOffset, byte[] out, int outOffset, Object sessionKey, int bs)
           
 Iterator keySizes()
          Returns an Iterator over the supported key sizes.
 Object makeKey(byte[] k, int bs)
          Expands a user-supplied key material into a session key for a designated block size.
 boolean selfTest()
          A correctness test that consists of basic symmetric encryption / decryption test(s) for all supported block and key sizes, as well as one (1) variable key Known Answer Test (KAT).
 
Methods inherited from class gnu.crypto.cipher.BaseCipher
currentBlockSize, decryptBlock, defaultBlockSize, defaultKeySize, encryptBlock, init, name, reset, testKat, testKat
 
Methods inherited from class java.lang.Object
equals, finalize, getClass, hashCode, notify, notifyAll, toString, wait, wait, wait
 

Constructor Detail

Twofish

public Twofish()
Trivial 0-arguments constructor.

Method Detail

clone

public Object clone()
Description copied from interface: IBlockCipher

Returns a clone of this instance.

Specified by:
clone in interface IBlockCipher
Specified by:
clone in class BaseCipher
Returns:
a clone copy of this instance.

blockSizes

public Iterator blockSizes()
Description copied from interface: IBlockCipher

Returns an Iterator over the supported block sizes. Each element returned by this object is an Integer.

Returns:
an Iterator over the supported block sizes.

keySizes

public Iterator keySizes()
Description copied from interface: IBlockCipher

Returns an Iterator over the supported key sizes. Each element returned by this object is an Integer.

Returns:
an Iterator over the supported key sizes.

makeKey

public Object makeKey(byte[] k,
                      int bs)
               throws InvalidKeyException

Expands a user-supplied key material into a session key for a designated block size.

Parameters:
k - the 64/128/192/256-bit user-key to use.
bs - the desired block size in bytes.
Returns:
an Object encapsulating the session key.
Throws:
IllegalArgumentException - if the block size is not 16 (128-bit).
InvalidKeyException - if the key data is invalid.

encrypt

public void encrypt(byte[] in,
                    int inOffset,
                    byte[] out,
                    int outOffset,
                    Object sessionKey,
                    int bs)

decrypt

public void decrypt(byte[] in,
                    int inOffset,
                    byte[] out,
                    int outOffset,
                    Object sessionKey,
                    int bs)

selfTest

public boolean selfTest()
Description copied from interface: IBlockCipher

A correctness test that consists of basic symmetric encryption / decryption test(s) for all supported block and key sizes, as well as one (1) variable key Known Answer Test (KAT).

Specified by:
selfTest in interface IBlockCipher
Specified by:
selfTest in interface IBlockCipherSpi
Overrides:
selfTest in class BaseCipher
Returns:
true if the implementation passes simple correctness tests. Returns false otherwise.

For the latest news and information visit
The GNU Crypto project

Copyright © 2001, 2002, 2003 Free Software Foundation, Inc. All Rights Reserved.