/** * Copyright (C) 2021 Saturneric * * 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 . * * 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 starting on May 12, 2021. * * SPDX-License-Identifier: GPL-3.0-or-later * */ #include "GlobalSettingStation.h" #include "core/function/FileOperator.h" void GpgFrontend::GlobalSettingStation::SyncSettings() noexcept { using namespace libconfig; try { ui_cfg_.writeFile(ui_config_path_.u8string().c_str()); SPDLOG_DEBUG("updated ui configuration successfully written to {}", ui_config_path_.u8string()); } catch (const FileIOException &fioex) { SPDLOG_ERROR("i/o error while writing ui configuration file: {}", ui_config_path_.u8string()); } } GpgFrontend::GlobalSettingStation::GlobalSettingStation(int channel) noexcept : SingletonFunctionObject(channel) { using namespace std::filesystem; using namespace libconfig; SPDLOG_INFO("app path: {}", app_path_.u8string()); SPDLOG_INFO("app configure path: {}", app_configure_path_.u8string()); SPDLOG_INFO("app data path: {}", app_data_path_.u8string()); SPDLOG_INFO("app log path: {}", app_log_path_.u8string()); SPDLOG_INFO("app locale path: {}", app_locale_path_.u8string()); SPDLOG_INFO("app conf path: {}", ui_config_path_.u8string()); SPDLOG_INFO("app log files total size: {}", GetLogFilesSize()); SPDLOG_INFO("app data objects files total size: {}", GetDataObjectsFilesSize()); if (!is_directory(app_configure_path_)) create_directory(app_configure_path_); if (!is_directory(app_data_path_)) create_directory(app_data_path_); if (!is_directory(app_log_path_)) create_directory(app_log_path_); if (!is_directory(ui_config_dir_path_)) create_directory(ui_config_dir_path_); if (!exists(ui_config_path_)) { try { this->ui_cfg_.writeFile(ui_config_path_.u8string().c_str()); SPDLOG_DEBUG("user interface configuration successfully written to {}", ui_config_path_.u8string()); } catch (const FileIOException &fioex) { SPDLOG_DEBUG( "i/o error while writing UserInterface configuration file {}", ui_config_path_.u8string()); } } else { try { this->ui_cfg_.readFile(ui_config_path_.u8string().c_str()); SPDLOG_DEBUG("user interface configuration successfully read from {}", ui_config_path_.u8string()); } catch (const FileIOException &fioex) { SPDLOG_ERROR("i/o error while reading UserInterface configure file"); } catch (const ParseException &pex) { SPDLOG_ERROR("parse error at {} : {} - {}", pex.getFile(), pex.getLine(), pex.getError()); } } } libconfig::Setting & GpgFrontend::GlobalSettingStation::GetUISettings() noexcept { return ui_cfg_.getRoot(); } void GpgFrontend::GlobalSettingStation::init_app_secure_key() {} int64_t GpgFrontend::GlobalSettingStation::get_files_size_at_path( std::filesystem::path path, std::string filename_pattern) const { auto dir = QDir(QString::fromStdString(path.u8string())); QFileInfoList fileList = dir.entryInfoList( QStringList() << QString::fromStdString(filename_pattern), QDir::Files); qint64 totalSize = 0; for (const QFileInfo &fileInfo : fileList) { totalSize += fileInfo.size(); } return totalSize; } std::string GpgFrontend::GlobalSettingStation::get_human_readable_size( int64_t size) const { double num = size; QStringList list; list << "KB" << "MB" << "GB" << "TB"; QStringListIterator i(list); QString unit("bytes"); while (num >= 1024.0 && i.hasNext()) { unit = i.next(); num /= 1024.0; } return (QString().setNum(num, 'f', 2) + " " + unit).toStdString(); } std::string GpgFrontend::GlobalSettingStation::GetLogFilesSize() const { return get_human_readable_size( get_files_size_at_path(app_log_path_, "*.log")); } std::string GpgFrontend::GlobalSettingStation::GetDataObjectsFilesSize() const { return get_human_readable_size( get_files_size_at_path(app_data_objs_path_, "*")); } void GpgFrontend::GlobalSettingStation::ClearAllLogFiles() const { delete_all_files(app_log_path_, "*.log"); } void GpgFrontend::GlobalSettingStation::ClearAllDataObjects() const { delete_all_files(app_data_objs_path_, "*"); } void GpgFrontend::GlobalSettingStation::delete_all_files( std::filesystem::path path, std::string filename_pattern) const { auto dir = QDir(QString::fromStdString(path.u8string())); // 使用name filters来只选取以.log结尾的文件 QStringList logFiles = dir.entryList( QStringList() << QString::fromStdString(filename_pattern), QDir::Files); // 遍历并删除所有符合条件的文件 for (const auto &file : logFiles) { QFile::remove(dir.absoluteFilePath(file)); } } GpgFrontend::GlobalSettingStation::~GlobalSettingStation() noexcept = default;