/* * Blowfish * (C) 1999-2009 Jack Lloyd * * Distributed under the terms of the Botan license */ #ifndef BOTAN_BLOWFISH_H__ #define BOTAN_BLOWFISH_H__ #include namespace Botan { /* * Blowfish */ class BOTAN_DLL Blowfish : public BlockCipher { public: void encrypt_n(const byte in[], byte out[], u32bit blocks) const; void decrypt_n(const byte in[], byte out[], u32bit blocks) const; void clear(); std::string name() const { return "Blowfish"; } BlockCipher* clone() const { return new Blowfish; } Blowfish() : BlockCipher(8, 1, 56) {} private: void key_schedule(const byte[], u32bit); void generate_sbox(u32bit[], u32bit, u32bit&, u32bit&) const; static const u32bit P_INIT[18]; static const u32bit S_INIT[1024]; SecureBuffer S; SecureBuffer P; }; } #endif