mirror of
https://github.com/RetroShare/RetroShare.git
synced 2025-01-07 05:38:09 -05:00
83 lines
1.9 KiB
C++
83 lines
1.9 KiB
C++
|
|
||
|
/*
|
||
|
* libretroshare/src/util: rsprint.cc
|
||
|
*
|
||
|
* RetroShare Utilities
|
||
|
*
|
||
|
* 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".
|
||
|
*
|
||
|
*/
|
||
|
|
||
|
#include "util/rsprint.h"
|
||
|
#include <iomanip>
|
||
|
#include <sstream>
|
||
|
#include <openssl/sha.h>
|
||
|
|
||
|
std::string RsUtil::BinToHex(std::string bin)
|
||
|
{
|
||
|
return BinToHex(bin.c_str(), bin.length());
|
||
|
}
|
||
|
|
||
|
std::string RsUtil::BinToHex(const char *arr, const uint32_t len)
|
||
|
{
|
||
|
std::ostringstream out;
|
||
|
|
||
|
for(uint32_t j = 0; j < len; j++)
|
||
|
{
|
||
|
out << std::hex << std::setw(2) << std::setfill('0') << (int32_t) (((const uint8_t *) arr)[j]);
|
||
|
}
|
||
|
return out.str();
|
||
|
}
|
||
|
|
||
|
|
||
|
std::string RsUtil::HashId(std::string id, bool reverse)
|
||
|
{
|
||
|
std::string hash;
|
||
|
std::string tohash;
|
||
|
if (reverse)
|
||
|
{
|
||
|
std::string::reverse_iterator rit;
|
||
|
for(rit = id.rbegin(); rit != id.rend(); rit++)
|
||
|
{
|
||
|
tohash += (*rit);
|
||
|
}
|
||
|
}
|
||
|
else
|
||
|
{
|
||
|
tohash = id;
|
||
|
}
|
||
|
|
||
|
SHA_CTX *sha_ctx = new SHA_CTX;
|
||
|
uint8_t sha_hash[SHA_DIGEST_LENGTH];
|
||
|
|
||
|
SHA1_Init(sha_ctx);
|
||
|
SHA1_Update(sha_ctx, tohash.c_str(), tohash.length());
|
||
|
SHA1_Final(sha_hash, sha_ctx);
|
||
|
|
||
|
for(uint16_t i = 0; i < SHA_DIGEST_LENGTH; i++)
|
||
|
{
|
||
|
hash += sha_hash[i];
|
||
|
}
|
||
|
|
||
|
/* cleanup */
|
||
|
delete sha_ctx;
|
||
|
|
||
|
return hash;
|
||
|
}
|