mirror of
https://github.com/RetroShare/RetroShare.git
synced 2025-02-12 04:41:35 -05:00
![chrisparker126](/assets/img/avatar_default.png)
git-svn-id: http://svn.code.sf.net/p/retroshare/code/trunk@7187 b45a01b8-16f6-495d-af2f-9b41ad6348cc
98 lines
1.9 KiB
C++
98 lines
1.9 KiB
C++
/*
|
|
* libretroshare/src/pqi: pqihash.h
|
|
*
|
|
* 3P/PQI network interface for RetroShare.
|
|
*
|
|
* Copyright 2008 by Robert Fernie.
|
|
*
|
|
* This library is free software; you can redistribute it and/or
|
|
* modify it under the terms of the GNU Library General Public
|
|
* License Version 2 as published by the Free Software Foundation.
|
|
*
|
|
* This library 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
|
|
* Library General Public License for more details.
|
|
*
|
|
* You should have received a copy of the GNU Library General Public
|
|
* License along with this library; if not, write to the Free Software
|
|
* Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307
|
|
* USA.
|
|
*
|
|
* Please report all bugs and problems to "retroshare@lunamutt.com".
|
|
*
|
|
*/
|
|
|
|
#ifndef PQI_HASH_
|
|
#define PQI_HASH_
|
|
|
|
#include <retroshare/rsids.h>
|
|
#include <openssl/sha.h>
|
|
#include <string>
|
|
#include <iomanip>
|
|
#include <string.h>
|
|
#include "util/rsstring.h"
|
|
#include "retroshare/rstypes.h"
|
|
#include <inttypes.h>
|
|
|
|
class pqihash
|
|
{
|
|
public:
|
|
pqihash()
|
|
{
|
|
|
|
sha_hash = new uint8_t[SHA_DIGEST_LENGTH];
|
|
memset(sha_hash,0,SHA_DIGEST_LENGTH*sizeof(uint8_t)) ;
|
|
sha_ctx = new SHA_CTX;
|
|
SHA1_Init(sha_ctx);
|
|
doHash = true;
|
|
}
|
|
|
|
~pqihash()
|
|
{
|
|
delete[] sha_hash;
|
|
delete sha_ctx;
|
|
}
|
|
|
|
|
|
void addData(const void *data, uint32_t len)
|
|
{
|
|
if (doHash)
|
|
{
|
|
SHA1_Update(sha_ctx, data, len);
|
|
}
|
|
}
|
|
|
|
void Complete(RsFileHash &hash)
|
|
{
|
|
if (!doHash)
|
|
{
|
|
hash = endHash;
|
|
return;
|
|
}
|
|
|
|
SHA1_Final(sha_hash, sha_ctx);
|
|
|
|
endHash.clear();
|
|
endHash = hash = Sha1CheckSum(sha_hash);
|
|
|
|
// for(int i = 0; i < SHA_DIGEST_LENGTH; i++)
|
|
// {
|
|
// rs_sprintf_append(endHash, "%02x", (unsigned int) (sha_hash[i]));
|
|
// }
|
|
// hash = endHash;
|
|
doHash = false;
|
|
|
|
return;
|
|
}
|
|
|
|
private:
|
|
|
|
bool doHash;
|
|
RsFileHash endHash;
|
|
uint8_t *sha_hash;
|
|
SHA_CTX *sha_ctx;
|
|
};
|
|
|
|
#endif
|