/* * CMAC * (C) 1999-2007,2014 Jack Lloyd * * Distributed under the terms of the Botan license */ #ifndef BOTAN_CMAC_H__ #define BOTAN_CMAC_H__ #include #include namespace Botan { /** * CMAC, also known as OMAC1 */ class BOTAN_DLL CMAC : public MessageAuthenticationCode { public: std::string name() const; size_t output_length() const { return m_cipher->block_size(); } MessageAuthenticationCode* clone() const; void clear(); Key_Length_Specification key_spec() const { return m_cipher->key_spec(); } /** * CMAC's polynomial doubling operation * @param in the input * @param polynomial the byte value of the polynomial */ static secure_vector poly_double(const secure_vector& in); /** * @param cipher the underlying block cipher to use */ CMAC(BlockCipher* cipher); CMAC(const CMAC&) = delete; CMAC& operator=(const CMAC&) = delete; private: void add_data(const byte[], size_t); void final_result(byte[]); void key_schedule(const byte[], size_t); std::unique_ptr m_cipher; secure_vector m_buffer, m_state, m_B, m_P; size_t m_position; }; } #endif