mirror of
https://git.tesses.org/tesses50/tessesframework.git
synced 2026-06-01 10:05:31 +00:00
87 lines
3.0 KiB
C++
87 lines
3.0 KiB
C++
/*
|
|
TessesFramework a library to make C++ easier for me, used in CrossLang:
|
|
https://git.tesses.org/tesses50/crosslang Copyright (C) 2026 Mike Nolan
|
|
|
|
This program 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.
|
|
|
|
This program 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 this program. If not, see <https://www.gnu.org/licenses/>.
|
|
*/
|
|
|
|
#pragma once
|
|
#include "../Streams/Stream.hpp"
|
|
namespace Tesses::Framework::Crypto {
|
|
bool HaveCrypto();
|
|
std::string Base64_Encode(std::vector<uint8_t> data);
|
|
std::vector<uint8_t> Base64_Decode(std::string str);
|
|
class Sha1 {
|
|
void *inner;
|
|
|
|
public:
|
|
Sha1();
|
|
bool Start();
|
|
bool Update(const uint8_t *buffer, size_t sz);
|
|
bool Update(std::shared_ptr<Tesses::Framework::Streams::Stream> strm);
|
|
std::vector<uint8_t> Finish();
|
|
~Sha1();
|
|
static std::vector<uint8_t> ComputeHash(const uint8_t *buffer, size_t len);
|
|
static std::vector<uint8_t>
|
|
ComputeHash(std::shared_ptr<Tesses::Framework::Streams::Stream> strm);
|
|
};
|
|
class Sha256 {
|
|
void *inner;
|
|
bool is224;
|
|
|
|
public:
|
|
Sha256();
|
|
bool Start(bool is224 = false);
|
|
bool Is224();
|
|
bool Update(const uint8_t *buffer, size_t sz);
|
|
bool Update(std::shared_ptr<Tesses::Framework::Streams::Stream> strm);
|
|
std::vector<uint8_t> Finish();
|
|
~Sha256();
|
|
static std::vector<uint8_t> ComputeHash(const uint8_t *buffer, size_t len,
|
|
bool is224 = false);
|
|
static std::vector<uint8_t>
|
|
ComputeHash(std::shared_ptr<Tesses::Framework::Streams::Stream> strm,
|
|
bool is224 = false);
|
|
};
|
|
class Sha512 {
|
|
void *inner;
|
|
bool is384;
|
|
|
|
public:
|
|
Sha512();
|
|
bool Start(bool is384 = false);
|
|
bool Is384();
|
|
bool Update(const uint8_t *buffer, size_t sz);
|
|
bool Update(std::shared_ptr<Tesses::Framework::Streams::Stream> strm);
|
|
std::vector<uint8_t> Finish();
|
|
~Sha512();
|
|
|
|
static std::vector<uint8_t> ComputeHash(const uint8_t *buffer, size_t len,
|
|
bool is384 = false);
|
|
static std::vector<uint8_t>
|
|
ComputeHash(std::shared_ptr<Tesses::Framework::Streams::Stream> strm,
|
|
bool is384 = false);
|
|
};
|
|
typedef enum {
|
|
VERSION_SHA1 = 1,
|
|
VERSION_SHA224 = 224,
|
|
VERSION_SHA256 = 256,
|
|
VERSION_SHA384 = 384,
|
|
VERSION_SHA512 = 512
|
|
} ShaVersion;
|
|
bool PBKDF2(std::vector<uint8_t> &output, std::string pass,
|
|
std::vector<uint8_t> &salt, long itterations, ShaVersion version);
|
|
|
|
bool RandomBytes(std::vector<uint8_t> &output, std::string personal_str);
|
|
} // namespace Tesses::Framework::Crypto
|