| 
 | For the latest news and information visit The GNU Crypto project | ||||||||||
| PREV CLASS NEXT CLASS | FRAMES NO FRAMES | ||||||||||
| SUMMARY: NESTED | FIELD | CONSTR | METHOD | DETAIL: FIELD | CONSTR | METHOD | ||||||||||
java.lang.Object | +--gnu.crypto.assembly.Stage
A Stage in a Cascade Cipher.
Each stage may be either an implementation of a Block Cipher Mode of
 Operation (IMode) or another Cascade Cipher (Cascade). Each
 stage has also a natural operational direction when constructed for
 inclusion within a Cascade. This natural direction dictates
 how data flows from one stage into another when stages are chained together
 in a cascade. One can think of a stage and its natural direction as the
 specification of how to wire the stage into the chain. The following diagrams
 may help understand the paradigme. The first shows two stages chained each
 with a Direction.FORWARD direction.
           FORWARD         FORWARD
       +------+       +-------+
       |      |       |       |
       |  +--in --+   |   +--in --+
    ---+  | Stage |   |   | Stage |  +---
          +--out--+   |   +--out--+  |
              |       |       |      |
              +-------+       +------+
 
 The second diagram shows two stages, one in a Direction.FORWARD
 direction, while the other is wired in a Direction.REVERSED
 direction.
           FORWARD         REVERSED
       +------+               +------+
       |      |               |      |
       |  +--in --+       +--in --+  |
    ---+  | Stage |       | Stage |  +---
          +--out--+       +--out--+
              |               |
              +---------------+
 
ModeStage, 
CascadeStage| Field Summary | |
|---|---|
| static java.lang.String | DIRECTION | 
| protected  Direction | forward | 
| protected  Direction | wired | 
| Constructor Summary | |
|---|---|
| protected  | Stage(Direction forwardDirection) | 
| Method Summary | |
|---|---|
| abstract  java.util.Set | blockSizes()Returns the Setof supported block sizes for thisStage. | 
| abstract  int | currentBlockSize()Returns the currently set block size for the stage. | 
| static Stage | getInstance(Cascade cascade,
            Direction forwardDirection) | 
| static Stage | getInstance(IMode mode,
            Direction forwardDirection) | 
|  void | init(java.util.Map attributes)Initialises the stage for operation with specific characteristics. | 
|  void | reset()Resets the stage for re-initialisation and use with other characteristics. | 
| abstract  boolean | selfTest()Conducts a simple correctness test that consists of basic symmetric encryption / decryption test(s) for all supported block and key sizes of underlying block cipher(s) wrapped by Mode leafs. | 
|  void | update(byte[] in,
       int inOffset,
       byte[] out,
       int outOffset)Processes exactly one block of plaintext (if initialised in the Direction.FORWARDstate) or ciphertext (if initialised in
 theDirection.REVERSEDstate). | 
| Methods inherited from class java.lang.Object | 
|---|
| clone, equals, finalize, getClass, hashCode, notify, notifyAll, toString, wait, wait, wait | 
| Field Detail | 
public static final java.lang.String DIRECTION
protected Direction forward
protected Direction wired
| Constructor Detail | 
protected Stage(Direction forwardDirection)
| Method Detail | 
public static final Stage getInstance(IMode mode,
                                      Direction forwardDirection)
public static final Stage getInstance(Cascade cascade,
                                      Direction forwardDirection)
public abstract java.util.Set blockSizes()
Set of supported block sizes for this
 Stage. Each element in the returned Set is an
 instance of Integer.
Set of supported block sizes.
public void init(java.util.Map attributes)
          throws java.security.InvalidKeyException
attributes - a set of name-value pairs that describes the desired
 future behaviour of this instance.
java.lang.IllegalStateException - if the instance is already initialised.
java.security.InvalidKeyException - if the key data is invalid.
public abstract int currentBlockSize()
                              throws java.lang.IllegalStateException
java.lang.IllegalStateException - if the instance is not initialised.public void reset()
public void update(byte[] in,
                   int inOffset,
                   byte[] out,
                   int outOffset)
Direction.FORWARD state) or ciphertext (if initialised in
 the Direction.REVERSED state).
in - the plaintext.inOffset - index of in from which to start considering
 data.out - the ciphertext.outOffset - index of out from which to store result.
java.lang.IllegalStateException - if the instance is not initialised.public abstract boolean selfTest()
true if the implementation passes simple
 correctness tests. Returns false otherwise.| 
 | For the latest news and information visit The GNU Crypto project | ||||||||||
| PREV CLASS NEXT CLASS | FRAMES NO FRAMES | ||||||||||
| SUMMARY: NESTED | FIELD | CONSTR | METHOD | DETAIL: FIELD | CONSTR | METHOD | ||||||||||