diff options
author | saturneric <[email protected]> | 2023-11-06 12:49:44 +0000 |
---|---|---|
committer | saturneric <[email protected]> | 2023-11-06 12:49:44 +0000 |
commit | 889cb8092381b073a0f4a0411a4ede04cd7bdd14 (patch) | |
tree | 87ae80ee7be8b426afe869baff7c99384bbafaaa /src/core/utils/IOUtils.cpp | |
parent | refactor: clean up core's codes (diff) | |
download | GpgFrontend-889cb8092381b073a0f4a0411a4ede04cd7bdd14.tar.gz GpgFrontend-889cb8092381b073a0f4a0411a4ede04cd7bdd14.zip |
refactor: improve the code structure of core
Diffstat (limited to 'src/core/utils/IOUtils.cpp')
-rw-r--r-- | src/core/utils/IOUtils.cpp | 139 |
1 files changed, 139 insertions, 0 deletions
diff --git a/src/core/utils/IOUtils.cpp b/src/core/utils/IOUtils.cpp new file mode 100644 index 00000000..5d0a2a54 --- /dev/null +++ b/src/core/utils/IOUtils.cpp @@ -0,0 +1,139 @@ +/** + * Copyright (C) 2021 Saturneric <[email protected]> + * + * This file is part of GpgFrontend. + * + * GpgFrontend 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. + * + * GpgFrontend 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 GpgFrontend. If not, see <https://www.gnu.org/licenses/>. + * + * The initial version of the source code is inherited from + * the gpg4usb project, which is under GPL-3.0-or-later. + * + * All the source code of GpgFrontend was modified and released by + * Saturneric <[email protected]> starting on May 12, 2021. + * + * SPDX-License-Identifier: GPL-3.0-or-later + * + */ + +#include "IOUtils.h" + +#include <sstream> + +#include "GpgModel.h" + +namespace GpgFrontend { + +auto ReadFile(const QString& file_name, QByteArray& data) -> bool { + QFile file(file_name); + if (!file.open(QIODevice::ReadOnly)) { + SPDLOG_ERROR("failed to open file: {}", file_name.toStdString()); + return false; + } + data = file.readAll(); + file.close(); + return true; +} + +auto WriteFile(const QString& file_name, const QByteArray& data) -> bool { + QFile file(file_name); + if (!file.open(QIODevice::WriteOnly)) { + SPDLOG_ERROR("failed to open file: {}", file_name.toStdString()); + return false; + } + file.write(data); + file.close(); + return true; +} + +auto ReadFileStd(const std::filesystem::path& file_name, std::string& data) + -> bool { + QByteArray byte_data; +#ifdef WINDOWS + bool res = ReadFile(QString::fromStdU16String(file_name.u16string()).toUtf8(), + byte_data); +#else + bool res = ReadFile(QString::fromStdString(file_name.u8string()).toUtf8(), + byte_data); +#endif + data = byte_data.toStdString(); + return res; +} + +auto WriteFileStd(const std::filesystem::path& file_name, + const std::string& data) -> bool { + return WriteFile(QString::fromStdString(file_name.u8string()).toUtf8(), + QByteArray::fromStdString(data)); +} + +auto CalculateHash(const std::filesystem::path& file_path) -> std::string { + // Returns empty QByteArray() on failure. + QFileInfo info(QString::fromStdString(file_path.string())); + std::stringstream ss; + + if (info.isFile() && info.isReadable()) { + ss << "[#] " << _("File Hash Information") << std::endl; + ss << " " << _("filename") << _(": ") + << file_path.filename().u8string().c_str() << std::endl; + + QFile f(info.filePath()); + if (f.open(QFile::ReadOnly)) { + // read all data + auto buffer = f.readAll(); + ss << " " << _("file size(bytes)") << _(": ") << buffer.size() + << std::endl; + + // md5 + auto hash_md5 = QCryptographicHash(QCryptographicHash::Md5); + hash_md5.addData(buffer); + auto md5 = hash_md5.result().toHex().toStdString(); + SPDLOG_DEBUG("md5 {}", md5); + ss << " " + << "md5" << _(": ") << md5 << std::endl; + + // sha1 + auto hash_sha1 = QCryptographicHash(QCryptographicHash::Sha1); + hash_sha1.addData(buffer); + auto sha1 = hash_sha1.result().toHex().toStdString(); + SPDLOG_DEBUG("sha1 {}", sha1); + ss << " " + << "sha1" << _(": ") << sha1 << std::endl; + + // sha1 + auto hash_sha256 = QCryptographicHash(QCryptographicHash::Sha256); + hash_sha256.addData(buffer); + auto sha256 = hash_sha256.result().toHex().toStdString(); + SPDLOG_DEBUG("sha256 {}", sha256); + ss << " " + << "sha256" << _(": ") << sha256 << std::endl; + + ss << std::endl; + } + } else { + ss << "[#] " << _("Error in Calculating File Hash ") << std::endl; + } + + return ss.str(); +} + +auto ReadAllDataInFile(const std::string& utf8_path) -> std::string { + std::string data; + ReadFileStd(utf8_path, data); + return data; +} + +auto WriteBufferToFile(const std::string& utf8_path, + const std::string& out_buffer) -> bool { + return WriteFileStd(utf8_path, out_buffer); +} +} // namespace GpgFrontend
\ No newline at end of file |