#ifndef CRYPTOPP_WAKE_H #define CRYPTOPP_WAKE_H #include "seckey.h" #include "secblock.h" #include "strciphr.h" NAMESPACE_BEGIN(CryptoPP) //! _ template struct WAKE_CFB_Info : public FixedKeyLength<32> { static const char *StaticAlgorithmName() {return B::ToEnum() == LITTLE_ENDIAN_ORDER ? "WAKE-CFB-LE" : "WAKE-CFB-BE";} }; //! _ template struct WAKE_OFB_Info : public FixedKeyLength<32> { static const char *StaticAlgorithmName() {return B::ToEnum() == LITTLE_ENDIAN_ORDER ? "WAKE-OFB-LE" : "WAKE-OFB-BE";} }; class CRYPTOPP_NO_VTABLE WAKE_Base { protected: word32 M(word32 x, word32 y); void GenKey(word32 k0, word32 k1, word32 k2, word32 k3); word32 t[257]; word32 r3, r4, r5, r6; }; template class CRYPTOPP_NO_VTABLE WAKE_Policy : public CFB_CipherConcretePolicy , public AdditiveCipherConcretePolicy , protected WAKE_Base { protected: void CipherSetKey(const NameValuePairs ¶ms, const byte *key, size_t length); // CFB byte * GetRegisterBegin() {return (byte *)&r6;} void Iterate(byte *output, const byte *input, CipherDir dir, size_t iterationCount); // OFB void OperateKeystream(KeystreamOperation operation, byte *output, const byte *input, size_t iterationCount); bool IsRandomAccess() const {return false;} }; namespace Weak { //! WAKE-CFB-BE template struct WAKE_CFB : public WAKE_CFB_Info, public SymmetricCipherDocumentation { typedef SymmetricCipherFinal, CFB_EncryptionTemplate<> >, WAKE_CFB_Info > Encryption; typedef SymmetricCipherFinal, CFB_DecryptionTemplate<> >, WAKE_CFB_Info > Decryption; }; } //! WAKE-OFB template struct WAKE_OFB : public WAKE_OFB_Info, public SymmetricCipherDocumentation { typedef SymmetricCipherFinal, AdditiveCipherTemplate<> >, WAKE_OFB_Info > Encryption; typedef Encryption Decryption; }; /* template class WAKE_ROFB_Policy : public WAKE_Policy { protected: void Iterate(KeystreamOperation operation, byte *output, const byte *input, unsigned int iterationCount); }; template struct WAKE_ROFB : public WAKE_Info { typedef SymmetricCipherTemplate, WAKE_ROFB_Policy > > Encryption; typedef Encryption Decryption; }; */ NAMESPACE_END #endif