forgetIt/CryptClass/HASHCrypt.cpp

78 lines
2.1 KiB
C++
Raw Normal View History

2015-03-06 11:06:27 +04:00
#include "HASHCrypt.hpp"
//Constructeur
HASHCrypt::HASHCrypt(){
2015-03-06 11:06:27 +04:00
}
2015-03-06 11:06:27 +04:00
//Destructeur
HASHCrypt::~HASHCrypt(){
}
/*
chain : objet de type string à hacher à l'aide de l'algorithme MD5
digest: tableau de type byte* contenant les données hasher
size: int faisant référence à la taille du tableau
Attention si size!=sizeof(digest) risque d'erreur de type Segmentation fault
*/
void HASHCrypt::getMD5_128(std::string chain, byte* digest, int size){
2015-03-06 11:06:27 +04:00
//Contrôle de la taille du digest
this->checkDigestSize(CryptoPP::Weak1::MD5::DIGESTSIZE,size);
2015-03-06 11:06:27 +04:00
//Calcule de la somme de controle MD5 dans un type byte* à partir du paramètre chain
2015-03-06 11:06:27 +04:00
CryptoPP::Weak1::MD5 hash;
hash.CalculateDigest( digest, (byte*) chain.c_str(), chain.length() );
2015-03-06 11:06:27 +04:00
}
/*
chain : objet de type string à hacher à l'aide de l'algorithme SHA-256
digest: tableau de type byte* contenant les données hasher
size : int faisant référence à la taille du tableau
Attention si size!=sizeof(digest) risque d'erreur de type Segmentation fault
2015-03-06 11:06:27 +04:00
*/
void HASHCrypt::getSHA_256(std::string chain, byte* digest, int size){
2015-03-06 11:06:27 +04:00
//Contrôle de la taille du digest
this->checkDigestSize(CryptoPP::SHA256::DIGESTSIZE,size);
//Calcule du SHA-256 dans un type byte* à partir du paramètre chain
CryptoPP::SHA256 hash;
hash.CalculateDigest( digest, (byte*) chain.c_str(), chain.length() );
2015-03-06 11:06:27 +04:00
}
/*
size : contient la taille des données passer en paramètre à la méthode de hashage choisi
*/
std::string HASHCrypt::getInvalidDigestSizeError(int sizeRequired, int size){
std::ostringstream erreurStream;
erreurStream << "Taille de digest invalide ! ("<< sizeRequired <<" octets requis et "<< size <<" donner)";
return erreurStream.str();
}
/*
sizeRequired : Taille du disgest attendu
size : Taille du digest donné
*/
void HASHCrypt::checkDigestSize(int sizeRequired, int size){
try{
if(size !=sizeRequired){
throw this->getInvalidDigestSizeError(sizeRequired, size);
}
}
catch(std::string erreur){
std::cerr << erreur <<std::endl;
std::exit(EXIT_FAILURE);
}
}