/************************************************* * EMSA Header File * * (C) 1999-2007 Jack Lloyd * *************************************************/ #ifndef BOTAN_EMSA_H__ #define BOTAN_EMSA_H__ #include namespace Botan { /************************************************* * EMSA1 * *************************************************/ class EMSA1 : public EMSA { public: EMSA1(const std::string&); ~EMSA1() { delete hash; } private: void update(const byte[], u32bit); SecureVector encoding_of(const MemoryRegion&, u32bit); SecureVector raw_data(); bool verify(const MemoryRegion&, const MemoryRegion&, u32bit) throw(); HashFunction* hash; }; /************************************************* * EMSA2 * *************************************************/ class EMSA2 : public EMSA { public: EMSA2(const std::string&); ~EMSA2() { delete hash; } private: void update(const byte[], u32bit); SecureVector encoding_of(const MemoryRegion&, u32bit); SecureVector raw_data(); SecureVector empty_hash; HashFunction* hash; byte hash_id; }; /************************************************* * EMSA3 * *************************************************/ class EMSA3 : public EMSA { public: EMSA3(const std::string&); ~EMSA3() { delete hash; } private: void update(const byte[], u32bit); SecureVector encoding_of(const MemoryRegion&, u32bit); SecureVector raw_data(); HashFunction* hash; SecureVector hash_id; }; /************************************************* * EMSA4 * *************************************************/ class EMSA4 : public EMSA { public: EMSA4(const std::string&, const std::string&); EMSA4(const std::string&, const std::string&, u32bit); ~EMSA4() { delete hash; delete mgf; } private: void update(const byte[], u32bit); SecureVector encoding_of(const MemoryRegion&, u32bit); SecureVector raw_data(); bool verify(const MemoryRegion&, const MemoryRegion&, u32bit) throw(); const u32bit SALT_SIZE; HashFunction* hash; const MGF* mgf; }; /************************************************* * EMSA-Raw * *************************************************/ class EMSA_Raw : public EMSA { private: void update(const byte[], u32bit); SecureVector encoding_of(const MemoryRegion&, u32bit); SecureVector raw_data(); SecureVector message; }; } #endif