ext-cryptopp/shacal2.h

54 lines
1.2 KiB
C
Raw Normal View History

2003-04-16 00:48:47 +00:00
#ifndef CRYPTOPP_SHACAL2_H
#define CRYPTOPP_SHACAL2_H
/** \file
*/
#include "seckey.h"
#include "secblock.h"
NAMESPACE_BEGIN(CryptoPP)
struct SHACAL2_Info : public FixedBlockSize<32>, public VariableKeyLength<16, 16, 64>
{
static const char *StaticAlgorithmName() {return "SHACAL-2";}
};
/// <a href="http://www.weidai.com/scan-mirror/cs.html#SHACAL-2">SHACAL-2</a>
class SHACAL2 : public SHACAL2_Info, public BlockCipherDocumentation
{
class CRYPTOPP_NO_VTABLE Base : public BlockCipherImpl<SHACAL2_Info>
2003-04-16 00:48:47 +00:00
{
public:
void UncheckedSetKey(CipherDir direction, const byte *userKey, unsigned int length);
protected:
FixedSizeSecBlock<word32, 64> m_key;
static const word32 K[64];
};
2003-05-16 00:53:53 +00:00
class CRYPTOPP_NO_VTABLE Enc : public Base
2003-04-16 00:48:47 +00:00
{
public:
void ProcessAndXorBlock(const byte *inBlock, const byte *xorBlock, byte *outBlock) const;
};
2003-05-16 00:53:53 +00:00
class CRYPTOPP_NO_VTABLE Dec : public Base
2003-04-16 00:48:47 +00:00
{
public:
void ProcessAndXorBlock(const byte *inBlock, const byte *xorBlock, byte *outBlock) const;
};
public:
typedef BlockCipherFinal<ENCRYPTION, Enc> Encryption;
typedef BlockCipherFinal<DECRYPTION, Dec> Decryption;
2003-04-16 00:48:47 +00:00
};
typedef SHACAL2::Encryption SHACAL2Encryption;
typedef SHACAL2::Decryption SHACAL2Decryption;
NAMESPACE_END
#endif