2020-11-12 12:00:50 +01:00
|
|
|
#pragma once
|
|
|
|
|
|
|
|
#include <hex.hpp>
|
|
|
|
|
|
|
|
#include <array>
|
|
|
|
#include <optional>
|
|
|
|
#include <string>
|
2020-11-24 02:00:22 +01:00
|
|
|
#include <vector>
|
2020-11-12 12:00:50 +01:00
|
|
|
|
2021-02-02 23:11:23 +01:00
|
|
|
namespace hex::prv { class Provider; }
|
2020-11-12 12:00:50 +01:00
|
|
|
|
2021-02-02 23:11:23 +01:00
|
|
|
namespace hex::crypt {
|
|
|
|
|
|
|
|
void initialize();
|
|
|
|
void exit();
|
2020-11-12 12:00:50 +01:00
|
|
|
|
|
|
|
u16 crc16(prv::Provider* &data, u64 offset, size_t size, u16 polynomial, u16 init);
|
|
|
|
u32 crc32(prv::Provider* &data, u64 offset, size_t size, u32 polynomial, u32 init);
|
|
|
|
|
2021-02-02 23:11:23 +01:00
|
|
|
std::array<u8, 16> md5(prv::Provider* &data, u64 offset, size_t size);
|
|
|
|
std::array<u8, 20> sha1(prv::Provider* &data, u64 offset, size_t size);
|
|
|
|
std::array<u8, 28> sha224(prv::Provider* &data, u64 offset, size_t size);
|
|
|
|
std::array<u8, 32> sha256(prv::Provider* &data, u64 offset, size_t size);
|
|
|
|
std::array<u8, 48> sha384(prv::Provider* &data, u64 offset, size_t size);
|
|
|
|
std::array<u8, 64> sha512(prv::Provider* &data, u64 offset, size_t size);
|
2020-11-12 12:00:50 +01:00
|
|
|
|
2020-11-24 02:00:22 +01:00
|
|
|
std::vector<u8> decode64(const std::vector<u8> &input);
|
|
|
|
std::vector<u8> encode64(const std::vector<u8> &input);
|
2021-02-03 11:54:41 +01:00
|
|
|
|
|
|
|
std::vector<u8> aesCtrDecrypt(const std::vector<u8> &key, std::array<u8, 8> nonce, std::array<u8, 8> iv, const std::vector<u8> &input);
|
2020-11-12 12:00:50 +01:00
|
|
|
}
|