NullCipher.h
Go to the documentation of this file.00001 
00002 
00003 
00004 
00005 
00006 
00007 
00008 
00009 
00010 
00011 
00012 
00013 
00014 
00015 
00016 
00017 
00018 
00023 #ifndef _CLASS_BEE_CRYPTO_NULLCIPHER_H
00024 #define _CLASS_BEE_CRYPTO_NULLCIPHER_H
00025 
00026 #ifdef __cplusplus
00027 
00028 #include "beecrypt/c++/crypto/Cipher.h"
00029 using beecrypt::crypto::Cipher;
00030 
00031 namespace beecrypt {
00032     namespace crypto {
00035         class BEECRYPTCXXAPI NullCipher : public Cipher
00036         {
00037         private:
00038             class NullCipherSpi : public CipherSpi
00039             {
00040             protected:
00041                 virtual bytearray* engineDoFinal(const byte* input, int inputOffset, int inputLength) throw (IllegalBlockSizeException, BadPaddingException);
00042                 virtual int engineDoFinal(const byte* input, int inputOffset, int inputLength, bytearray& output, int outputOffset) throw (ShortBufferException, IllegalBlockSizeException, BadPaddingException);
00043 
00044                 virtual int engineGetBlockSize() const throw ();
00045                 virtual bytearray* engineGetIV();
00046                 virtual int engineGetOutputSize(int inputLength) throw ();
00047                 virtual AlgorithmParameters* engineGetParameters() throw ();
00048 
00049                 virtual void engineInit(int opmode, const Key& key, SecureRandom* random) throw (InvalidKeyException);
00050                 virtual void engineInit(int opmode, const Key& key, AlgorithmParameters* params, SecureRandom* random) throw (InvalidKeyException, InvalidAlgorithmParameterException);
00051                 virtual void engineInit(int opmode, const Key& key, const AlgorithmParameterSpec& params, SecureRandom* random) throw (InvalidKeyException, InvalidAlgorithmParameterException);
00052 
00053                 virtual void engineSetMode(const String& mode) throw (NoSuchAlgorithmException);
00054                 virtual void engineSetPadding(const String& padding) throw (NoSuchPaddingException);
00055 
00056                 virtual bytearray* engineUpdate(const byte* input, int inputOffset, int inputLength);
00057                 virtual int engineUpdate(const byte* input, int inputOffset, int inputLength, bytearray& output, int outputOffset) throw (ShortBufferException);
00058             };
00059 
00060         public:
00061             NullCipher();
00062             virtual ~NullCipher() {}
00063         };
00064     }
00065 }
00066 
00067 #endif
00068 
00069 #endif