mirror of
https://github.com/geode-sdk/geode.git
synced 2024-11-22 15:37:53 -05:00
check hash for downloaded mods
This commit is contained in:
parent
af17213798
commit
61e000daa0
3 changed files with 20 additions and 4 deletions
|
@ -52,6 +52,8 @@ std::string calculateSHA256Text(std::filesystem::path const& path) {
|
|||
return picosha2::bytes_to_hex_string(hash.begin(), hash.end());
|
||||
}
|
||||
|
||||
std::string calculateHash(std::filesystem::path const& path) {
|
||||
return calculateSHA3_256(path);
|
||||
std::string calculateHash(std::span<const uint8_t> data) {
|
||||
std::vector<uint8_t> hash(picosha2::k_digest_size);
|
||||
picosha2::hash256(data.begin(), data.end(), hash);
|
||||
return picosha2::bytes_to_hex_string(hash.begin(), hash.end());
|
||||
}
|
|
@ -2,6 +2,7 @@
|
|||
|
||||
#include <string>
|
||||
#include <filesystem>
|
||||
#include <span>
|
||||
|
||||
std::string calculateSHA3_256(std::filesystem::path const& path);
|
||||
|
||||
|
@ -9,4 +10,8 @@ std::string calculateSHA256(std::filesystem::path const& path);
|
|||
|
||||
std::string calculateSHA256Text(std::filesystem::path const& path);
|
||||
|
||||
std::string calculateHash(std::filesystem::path const& path);
|
||||
/**
|
||||
* Calculates the SHA256 hash of the given data,
|
||||
* used for verifying mods.
|
||||
*/
|
||||
std::string calculateHash(std::span<const uint8_t> data);
|
||||
|
|
|
@ -3,6 +3,7 @@
|
|||
#include <Geode/loader/Dirs.hpp>
|
||||
#include <Geode/utils/map.hpp>
|
||||
#include <optional>
|
||||
#include <hash/hash.hpp>
|
||||
|
||||
using namespace server;
|
||||
|
||||
|
@ -103,8 +104,16 @@ public:
|
|||
m_downloadListener.bind([this, hash = version.hash](web::WebTask::Event* event) {
|
||||
if (auto value = event->getValue()) {
|
||||
if (value->ok()) {
|
||||
if (auto actualHash = ::calculateHash(value->data()); actualHash != hash) {
|
||||
log::error("Failed to download {}, hash mismatch ({} != {})", m_id, actualHash, hash);
|
||||
m_status = DownloadStatusError {
|
||||
.details = "Hash mismatch, downloaded file did not match what was expected",
|
||||
};
|
||||
ModDownloadEvent(m_id).post();
|
||||
return;
|
||||
}
|
||||
|
||||
bool removingInstalledWasError = false;
|
||||
bool disablingReplacedWasError = false;
|
||||
std::string id = m_replacesMod.has_value() ? m_replacesMod.value() : m_id;
|
||||
if (auto mod = Loader::get()->getInstalledMod(id)) {
|
||||
std::error_code ec;
|
||||
|
|
Loading…
Reference in a new issue