mirror of
https://github.com/ClickHouse/ClickHouse.git
synced 2024-09-30 21:50:49 +00:00
785d1b2a75
Add few more specializations for encodeSHA256(): - std::string encodeSHA256(const std::string_view &); - std::string encodeSHA256(const void *, size_t); - void encodeSHA256(const void *, size_t, unsigned char *);
50 lines
1.1 KiB
C++
50 lines
1.1 KiB
C++
#if !defined(ARCADIA_BUILD)
|
|
# include <Common/config.h>
|
|
#endif
|
|
|
|
#if USE_SSL
|
|
#include "OpenSSLHelpers.h"
|
|
#include <ext/scope_guard.h>
|
|
#include <openssl/err.h>
|
|
#include <openssl/sha.h>
|
|
|
|
namespace DB
|
|
{
|
|
#pragma GCC diagnostic warning "-Wold-style-cast"
|
|
|
|
std::string encodeSHA256(const std::string_view & text)
|
|
{
|
|
return encodeSHA256(text.data(), text.size());
|
|
}
|
|
std::string encodeSHA256(const void * text, size_t size)
|
|
{
|
|
std::string out;
|
|
out.resize(32);
|
|
encodeSHA256(text, size, reinterpret_cast<unsigned char *>(out.data()));
|
|
return out;
|
|
}
|
|
void encodeSHA256(const std::string_view & text, unsigned char * out)
|
|
{
|
|
encodeSHA256(text.data(), text.size(), out);
|
|
}
|
|
void encodeSHA256(const void * text, size_t size, unsigned char * out)
|
|
{
|
|
SHA256_CTX ctx;
|
|
SHA256_Init(&ctx);
|
|
SHA256_Update(&ctx, reinterpret_cast<const UInt8 *>(text), size);
|
|
SHA256_Final(out, &ctx);
|
|
}
|
|
|
|
String getOpenSSLErrors()
|
|
{
|
|
BIO * mem = BIO_new(BIO_s_mem());
|
|
SCOPE_EXIT(BIO_free(mem));
|
|
ERR_print_errors(mem);
|
|
char * buf = nullptr;
|
|
size_t size = BIO_get_mem_data(mem, &buf);
|
|
return String(buf, size);
|
|
}
|
|
|
|
}
|
|
#endif
|