/*************************************************
* EMSA Header File *
* (C) 1999-2007 The Botan Project *
*************************************************/
#ifndef BOTAN_EMSA_H__
#define BOTAN_EMSA_H__
#include <botan/pk_util.h>
namespace Botan {
/*************************************************
* EMSA1 *
*************************************************/
class EMSA1 : public EMSA
{
public:
EMSA1(const std::string&);
~EMSA1() { delete hash; }
private:
void update(const byte[], u32bit);
SecureVector<byte> encoding_of(const MemoryRegion<byte>&, u32bit);
SecureVector<byte> raw_data();
bool verify(const MemoryRegion<byte>&, const MemoryRegion<byte>&,
u32bit) throw();
HashFunction* hash;
};
/*************************************************
* EMSA2 *
*************************************************/
class EMSA2 : public EMSA
{
public:
EMSA2(const std::string&);
~EMSA2() { delete hash; }
private:
void update(const byte[], u32bit);
SecureVector<byte> encoding_of(const MemoryRegion<byte>&, u32bit);
SecureVector<byte> raw_data();
SecureVector<byte> 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<byte> encoding_of(const MemoryRegion<byte>&, u32bit);
SecureVector<byte> raw_data();
HashFunction* hash;
SecureVector<byte> 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<byte> encoding_of(const MemoryRegion<byte>&, u32bit);
SecureVector<byte> raw_data();
bool verify(const MemoryRegion<byte>&, const MemoryRegion<byte>&,
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<byte> encoding_of(const MemoryRegion<byte>&, u32bit);
SecureVector<byte> raw_data();
SecureVector<byte> message;
};
}
#endif
syntax highlighted by Code2HTML, v. 0.9.1