12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576777879808182838485868788899091929394959697 |
- /* Copyright (C) 2014 Carlos Aguilar Melchor, Joris Barrier, Marc-Olivier Killijian
- * This file is part of XPIR.
- *
- * XPIR is free software: you can redistribute it and/or modify
- * it under the terms of the GNU General Public License as published by
- * the Free Software Foundation, either version 3 of the License, or
- * (at your option) any later version.
- *
- * XPIR 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 General Public License for more details.
- *
- * You should have received a copy of the GNU General Public License
- * along with XPIR. If not, see <http://www.gnu.org/licenses/>.
- */
- #ifndef DEF_PAILLIERADAPTER
- #define DEF_PAILLIERADAPTER
- static const unsigned int kNumSecurityBits = 80;
- #include <fstream>
- #include <omp.h>
- #include <math.h>
- #include <string>
- #include <unistd.h>
- #include <boost/algorithm/string.hpp>
- #include "HomomorphicCrypto.hpp"
- #include "PaillierPublicParameters.hpp"
- #include "PaillierPrivateParameters.hpp"
- using namespace std;
- class PaillierAdapter : public HomomorphicCrypto {
- private:
- /*Attributs*/
- gmp_randstate_t rand;
- int unsigned modulusbits;
- int security_bits;
- PaillierPrivateParameters privateParameters;
-
- /*Methods*/
- void keygen(unsigned int modulusbits,
- paillier_pubkey* pub,
- paillier_prvkey* prv,
- unsigned int s);
- void complete_prvkey( paillier_prvkey* prv,
- paillier_pubkey* pub,
- unsigned int s );
- void generatePrivateKey(void);
- void generatePublicKey(void);
- void enc(paillier_pubkey* pub,
- mpz_t m,
- unsigned int s,
- mpz_t c
- );
-
- void dec( paillier_pubkey* pub,
- paillier_prvkey* prv,
- mpz_t ct,
- unsigned int,
- mpz_t i);
- void getRandFromfile( int len, mpz_t* val );
- void getRandInteger(mpz_t rop, unsigned int length, gmp_randstate_t prng);
- void initRandomGenerator();
- public:
- void e_add(mpz_t res, mpz_t a, mpz_t b, int);
- void e_mul_const(mpz_t res, mpz_t a, mpz_t n, int);
- static unsigned int securityToModulus(int);
- /*Attributs*/
- PaillierPublicParameters publicParameters;
-
- /*Methods*/
- char* encrypt(unsigned int ui, unsigned int);
- char* encrypt(char* data, size_t, unsigned int exponent);
- char* encrypt_perftest();
- char* decrypt(char* cipheredData, unsigned int rec_lvl, size_t, size_t);
- unsigned int getCryptoParams(unsigned int k,set<std::string>& crypto_params);
- unsigned int getAllCryptoParams(set<std::string>& crypto_params);
- long setandgetAbsBitPerCiphertext(unsigned int elt_nbr);
- std::string getSerializedCryptoParams(bool shortversion);
- PaillierAdapter();
- PaillierAdapter(int security_bits, int recLvl);
- ~PaillierAdapter(void);
-
- double estimateAbsTime(std::string crypto_param);
- AbstractPublicParameters& getPublicParameters(void);
- double getDecCost(unsigned int length, unsigned int s);
- void setNewParameters(const std::string& crypto_params);
- void get_prime_of_size(mpz_t rop, unsigned int size);
- };
- #endif
|