2013-01-16 21:30:03 +00:00
|
|
|
|
|
|
|
/*
|
|
|
|
* This file is part of Codecrypt.
|
|
|
|
*
|
|
|
|
* Codecrypt is free software: you can redistribute it and/or modify it
|
|
|
|
* under the terms of the GNU Lesser General Public License as published by
|
|
|
|
* the Free Software Foundation, either version 3 of the License, or (at
|
|
|
|
* your option) any later version.
|
|
|
|
*
|
|
|
|
* Codecrypt is distributed in the hope that it will be useful, but WITHOUT
|
|
|
|
* ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
|
|
|
|
* FITNESS FOR A PARTICULAR PURPOSE. See the GNU Lesser General Public
|
|
|
|
* License for more details.
|
|
|
|
*
|
|
|
|
* You should have received a copy of the GNU Lesser General Public License
|
|
|
|
* along with Codecrypt. If not, see <http://www.gnu.org/licenses/>.
|
|
|
|
*/
|
|
|
|
|
|
|
|
#ifndef _ccr_enc_algs_h_
|
|
|
|
#define _ccr_enc_algs_h_
|
|
|
|
|
|
|
|
#include "algorithm.h"
|
|
|
|
|
2013-09-30 09:49:42 +00:00
|
|
|
#if HAVE_CRYPTOPP==1
|
|
|
|
|
2013-09-29 18:48:59 +00:00
|
|
|
/*
|
|
|
|
* SHA-based variants
|
|
|
|
*/
|
|
|
|
|
2013-01-16 21:30:03 +00:00
|
|
|
class algo_mceqd128 : public algorithm
|
|
|
|
{
|
|
|
|
public:
|
|
|
|
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);
|
|
|
|
};
|
|
|
|
|
2013-05-01 14:44:31 +00:00
|
|
|
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);
|
|
|
|
};
|
|
|
|
|
2013-01-16 21:30:03 +00:00
|
|
|
class algo_mceqd256 : public algorithm
|
|
|
|
{
|
|
|
|
public:
|
|
|
|
bool provides_signatures() {
|
|
|
|
return false;
|
|
|
|
}
|
|
|
|
|
|
|
|
bool provides_encryption() {
|
|
|
|
return true;
|
|
|
|
}
|
|
|
|
|
|
|
|
std::string get_alg_id() {
|
2013-01-17 15:31:34 +00:00
|
|
|
return "MCEQD256FO-SHA512-ARCFOUR";
|
2013-01-16 21:30:03 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
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);
|
|
|
|
};
|
|
|
|
|
2013-09-30 09:49:42 +00:00
|
|
|
#endif //HAVE_CRYPTOPP==1
|
|
|
|
|
2013-09-29 18:48:59 +00:00
|
|
|
/*
|
|
|
|
* Cubehash-based variants
|
|
|
|
*/
|
|
|
|
|
|
|
|
class algo_mceqd128cube : public algorithm
|
|
|
|
{
|
|
|
|
public:
|
|
|
|
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);
|
|
|
|
};
|
|
|
|
|
2013-01-16 21:30:03 +00:00
|
|
|
#endif
|
|
|
|
|