algos_enc: macro-squash algorighm definitions

This commit is contained in:
Mirek Kratochvil 2014-04-09 15:29:34 +02:00
parent c85a3f72a5
commit 5c739804fd
2 changed files with 96 additions and 313 deletions

View file

@ -38,40 +38,6 @@ static int mceqd_create_keypair (sencode**pub, sencode**priv, prng&rng)
return 0; return 0;
} }
#if HAVE_CRYPTOPP==1
int algo_mceqd128::create_keypair (sencode**pub, sencode**priv, prng&rng)
{
return mceqd_create_keypair<16, 7, 32, 4> (pub, priv, rng);
}
int algo_mceqd192::create_keypair (sencode**pub, sencode**priv, prng&rng)
{
return mceqd_create_keypair<16, 8, 27, 4> (pub, priv, rng);
}
int algo_mceqd256::create_keypair (sencode**pub, sencode**priv, prng&rng)
{
return mceqd_create_keypair<16, 8, 32, 4> (pub, priv, rng);
}
#endif //HAVE_CRYPTOPP==1
int algo_mceqd128cube::create_keypair (sencode**pub, sencode**priv, prng&rng)
{
return mceqd_create_keypair<16, 7, 32, 4> (pub, priv, rng);
}
int algo_mceqd192cube::create_keypair (sencode**pub, sencode**priv, prng&rng)
{
return mceqd_create_keypair<16, 8, 27, 4> (pub, priv, rng);
}
int algo_mceqd256cube::create_keypair (sencode**pub, sencode**priv, prng&rng)
{
return mceqd_create_keypair<16, 8, 32, 4> (pub, priv, rng);
}
/* /*
* Padding. Ha-ha. * Padding. Ha-ha.
* *
@ -427,174 +393,95 @@ static int fo_decrypt (const bvector&cipher, bvector&plain,
} }
/* /*
* Instances for actual encryption/descryption algorithms * Instances for actual keygen/encryption/descryption algorithms
*/ */
#define mceqd_create_keypair_func(name,m,T,b,d) \
int algo_mceqd##name::create_keypair (sencode**pub, sencode**priv, prng&rng) \
{ \
return mceqd_create_keypair<m, T, b, d> (pub, priv, rng); \
}
#if HAVE_CRYPTOPP==1
mceqd_create_keypair_func (128, 16, 7, 32, 4)
mceqd_create_keypair_func (192, 16, 8, 27, 4)
mceqd_create_keypair_func (256, 16, 8, 32, 4)
#endif //HAVE_CRYPTOPP==1
mceqd_create_keypair_func (128cube, 16, 7, 32, 4)
mceqd_create_keypair_func (192cube, 16, 8, 27, 4)
mceqd_create_keypair_func (256cube, 16, 8, 32, 4)
#include "arcfour.h" #include "arcfour.h"
typedef arcfour<byte, 8, 4096> arcfour_fo_cipher; typedef arcfour<byte, 8, 4096> arcfour_fo_cipher;
#define mceqd_create_encdec_func(name,plainsize,ciphersize,errcount, hash_type,pad_hash_type,scipher,ranksize) \
int algo_mceqd##name::encrypt (const bvector&plain, bvector&cipher, \
sencode* pubkey, prng&rng) \
{ \
return fo_encrypt \
< mce_qd::pubkey, \
plainsize, ciphersize, errcount, \
hash_type, \
pad_hash_type, \
scipher, \
ranksize > \
(plain, cipher, pubkey, rng); \
} \
int algo_mceqd##name::decrypt (const bvector&cipher, bvector&plain, \
sencode* privkey) \
{ \
return fo_decrypt \
< mce_qd::privkey, \
plainsize, ciphersize, errcount, \
hash_type, \
pad_hash_type, \
scipher, \
ranksize > \
(cipher, plain, privkey); \
}
#if HAVE_CRYPTOPP==1 #if HAVE_CRYPTOPP==1
#include "sha_hash.h" #include "sha_hash.h"
#include "rmd_hash.h" #include "rmd_hash.h"
int algo_mceqd128::encrypt (const bvector&plain, bvector&cipher, mceqd_create_encdec_func (128, 2048, 4096, 128,
sencode* pubkey, prng&rng) sha256hash, rmd128hash,
{
return fo_encrypt
< mce_qd::pubkey,
2048, 4096, 128,
sha256hash,
rmd128hash,
arcfour_fo_cipher, arcfour_fo_cipher,
816 > 816)
(plain, cipher, pubkey, rng);
}
int algo_mceqd192::encrypt (const bvector&plain, bvector&cipher,
sencode* pubkey, prng&rng)
{
return fo_encrypt
< mce_qd::pubkey,
2816, 6912, 256,
sha384hash,
rmd128hash,
arcfour_fo_cipher,
1574 >
(plain, cipher, pubkey, rng);
}
int algo_mceqd256::encrypt (const bvector&plain, bvector&cipher, mceqd_create_encdec_func (192, 2816, 6912, 256,
sencode* pubkey, prng&rng) sha384hash, rmd128hash,
{
return fo_encrypt
< mce_qd::pubkey,
4096, 8192, 256,
sha512hash,
rmd128hash,
arcfour_fo_cipher, arcfour_fo_cipher,
1638 > 1574)
(plain, cipher, pubkey, rng);
}
int algo_mceqd128::decrypt (const bvector&cipher, bvector&plain, mceqd_create_encdec_func (256, 4096, 8192, 256,
sencode* privkey) sha512hash, rmd128hash,
{
return fo_decrypt
< mce_qd::privkey,
2048, 4096, 128,
sha256hash,
rmd128hash,
arcfour_fo_cipher, arcfour_fo_cipher,
816 > 1638)
(cipher, plain, privkey);
}
int algo_mceqd192::decrypt (const bvector&cipher, bvector&plain,
sencode* privkey)
{
return fo_decrypt
< mce_qd::privkey,
2816, 6912, 256,
sha384hash,
rmd128hash,
arcfour_fo_cipher,
1574 >
(cipher, plain, privkey);
}
int algo_mceqd256::decrypt (const bvector&cipher, bvector&plain,
sencode* privkey)
{
return fo_decrypt
< mce_qd::privkey,
4096, 8192, 256,
sha512hash,
rmd128hash,
arcfour_fo_cipher,
1638 >
(cipher, plain, privkey);
}
#endif //HAVE_CRYPTOPP==1 #endif //HAVE_CRYPTOPP==1
#include "cube_hash.h" #include "cube_hash.h"
int algo_mceqd128cube::encrypt (const bvector&plain, bvector&cipher, mceqd_create_encdec_func (128cube, 2048, 4096, 128,
sencode* pubkey, prng&rng) cube256hash, cube128hash,
{
return fo_encrypt
< mce_qd::pubkey,
2048, 4096, 128,
cube256hash,
cube128hash,
arcfour_fo_cipher, arcfour_fo_cipher,
816 > 816)
(plain, cipher, pubkey, rng);
}
int algo_mceqd192cube::encrypt (const bvector&plain, bvector&cipher,
sencode* pubkey, prng&rng)
{
return fo_encrypt
< mce_qd::pubkey,
2816, 6912, 256,
cube384hash,
cube128hash,
arcfour_fo_cipher,
1574 >
(plain, cipher, pubkey, rng);
}
int algo_mceqd256cube::encrypt (const bvector&plain, bvector&cipher, mceqd_create_encdec_func (192cube, 2816, 6912, 256,
sencode* pubkey, prng&rng) cube384hash, cube128hash,
{
return fo_encrypt
< mce_qd::pubkey,
4096, 8192, 256,
cube512hash,
cube128hash,
arcfour_fo_cipher, arcfour_fo_cipher,
1638 > 1574)
(plain, cipher, pubkey, rng);
}
int algo_mceqd128cube::decrypt (const bvector&cipher, bvector&plain, mceqd_create_encdec_func (256cube, 4096, 8192, 256,
sencode* privkey) cube512hash, cube128hash,
{
return fo_decrypt
< mce_qd::privkey,
2048, 4096, 128,
cube256hash,
cube128hash,
arcfour_fo_cipher, arcfour_fo_cipher,
816 > 1638)
(cipher, plain, privkey);
}
int algo_mceqd192cube::decrypt (const bvector&cipher, bvector&plain,
sencode* privkey)
{
return fo_decrypt
< mce_qd::privkey,
2816, 6912, 256,
cube384hash,
cube128hash,
arcfour_fo_cipher,
1574 >
(cipher, plain, privkey);
}
int algo_mceqd256cube::decrypt (const bvector&cipher, bvector&plain,
sencode* privkey)
{
return fo_decrypt
< mce_qd::privkey,
4096, 8192, 256,
cube512hash,
cube128hash,
arcfour_fo_cipher,
1638 >
(cipher, plain, privkey);
}

View file

@ -21,77 +21,35 @@
#include "algorithm.h" #include "algorithm.h"
#define mceqd_alg_class(name,alg_id) \
class algo_mceqd##name : public algorithm \
{ \
public: \
bool provides_signatures() { \
return false; \
} \
bool provides_encryption() { \
return true; \
} \
std::string get_alg_id() { \
return (alg_id); \
} \
int encrypt (const bvector&plain, bvector&cipher, \
sencode* pubkey, prng&rng); \
int decrypt (const bvector&cipher, bvector&plain, \
sencode* privkey); \
int create_keypair (sencode**pub, sencode**priv, prng&rng); \
}
#if HAVE_CRYPTOPP==1 #if HAVE_CRYPTOPP==1
/* /*
* SHA-based variants * SHA-based variants
*/ */
class algo_mceqd128 : public algorithm mceqd_alg_class (128, "MCEQD128FO-SHA256-ARCFOUR");
{ mceqd_alg_class (192, "MCEQD192FO-SHA384-ARCFOUR");
public: mceqd_alg_class (256, "MCEQD256FO-SHA512-ARCFOUR");
bool provides_signatures() {
return false;
}
bool provides_encryption() {
return true;
}
std::string get_alg_id() {
return "MCEQD128FO-SHA256-ARCFOUR";
}
int encrypt (const bvector&plain, bvector&cipher,
sencode* pubkey, prng&rng);
int decrypt (const bvector&cipher, bvector&plain,
sencode* privkey);
int create_keypair (sencode**pub, sencode**priv, prng&rng);
};
class algo_mceqd192 : public algorithm
{
public:
bool provides_signatures() {
return false;
}
bool provides_encryption() {
return true;
}
std::string get_alg_id() {
return "MCEQD192FO-SHA384-ARCFOUR";
}
int encrypt (const bvector&plain, bvector&cipher,
sencode* pubkey, prng&rng);
int decrypt (const bvector&cipher, bvector&plain,
sencode* privkey);
int create_keypair (sencode**pub, sencode**priv, prng&rng);
};
class algo_mceqd256 : public algorithm
{
public:
bool provides_signatures() {
return false;
}
bool provides_encryption() {
return true;
}
std::string get_alg_id() {
return "MCEQD256FO-SHA512-ARCFOUR";
}
int encrypt (const bvector&plain, bvector&cipher,
sencode* pubkey, prng&rng);
int decrypt (const bvector&cipher, bvector&plain,
sencode* privkey);
int create_keypair (sencode**pub, sencode**priv, prng&rng);
};
#endif //HAVE_CRYPTOPP==1 #endif //HAVE_CRYPTOPP==1
@ -99,71 +57,9 @@ public:
* Cubehash-based variants * Cubehash-based variants
*/ */
class algo_mceqd128cube : public algorithm mceqd_alg_class (128cube, "MCEQD128FO-CUBE256-ARCFOUR");
{ mceqd_alg_class (192cube, "MCEQD192FO-CUBE384-ARCFOUR");
public: mceqd_alg_class (256cube, "MCEQD256FO-CUBE512-ARCFOUR");
bool provides_signatures() {
return false;
}
bool provides_encryption() {
return true;
}
std::string get_alg_id() {
return "MCEQD128FO-CUBE256-ARCFOUR";
}
int encrypt (const bvector&plain, bvector&cipher,
sencode* pubkey, prng&rng);
int decrypt (const bvector&cipher, bvector&plain,
sencode* privkey);
int create_keypair (sencode**pub, sencode**priv, prng&rng);
};
class algo_mceqd192cube : public algorithm
{
public:
bool provides_signatures() {
return false;
}
bool provides_encryption() {
return true;
}
std::string get_alg_id() {
return "MCEQD192FO-CUBE384-ARCFOUR";
}
int encrypt (const bvector&plain, bvector&cipher,
sencode* pubkey, prng&rng);
int decrypt (const bvector&cipher, bvector&plain,
sencode* privkey);
int create_keypair (sencode**pub, sencode**priv, prng&rng);
};
class algo_mceqd256cube : public algorithm
{
public:
bool provides_signatures() {
return false;
}
bool provides_encryption() {
return true;
}
std::string get_alg_id() {
return "MCEQD256FO-CUBE512-ARCFOUR";
}
int encrypt (const bvector&plain, bvector&cipher,
sencode* pubkey, prng&rng);
int decrypt (const bvector&cipher, bvector&plain,
sencode* privkey);
int create_keypair (sencode**pub, sencode**priv, prng&rng);
};
#endif #endif