2023-07-01 03:45:33 +08:00
|
|
|
#include "chwd_profiles.hpp"
|
|
|
|
#include "utils.hpp"
|
|
|
|
|
2024-06-26 05:49:53 +08:00
|
|
|
// import gucc
|
2024-06-26 20:54:04 +08:00
|
|
|
#include "gucc/io_utils.hpp"
|
2024-06-26 20:16:34 +08:00
|
|
|
#include "gucc/string_utils.hpp"
|
2024-06-26 05:49:53 +08:00
|
|
|
|
2024-07-13 08:24:37 +08:00
|
|
|
#include <algorithm> // for contains, sort, for_each
|
|
|
|
#include <ranges> // for ranges::*
|
2023-07-01 03:45:33 +08:00
|
|
|
|
|
|
|
#include <fmt/compile.h>
|
|
|
|
#include <fmt/format.h>
|
|
|
|
|
|
|
|
#define TOML_EXCEPTIONS 0 // disable exceptions
|
|
|
|
#include <toml++/toml.h>
|
|
|
|
|
|
|
|
namespace detail::chwd {
|
|
|
|
|
|
|
|
auto get_all_profile_names(std::string_view profile_type) noexcept -> std::optional<std::vector<std::string>> {
|
|
|
|
const auto& file_path = fmt::format(FMT_COMPILE("/var/lib/chwd/db/pci/{}/profiles.toml"), profile_type);
|
|
|
|
toml::parse_result config = toml::parse_file(file_path);
|
|
|
|
/* clang-format off */
|
|
|
|
if (config.failed()) { return {}; }
|
|
|
|
/* clang-format on */
|
|
|
|
|
|
|
|
std::vector<std::string> profile_names{};
|
|
|
|
for (auto&& [key, value] : config.table()) {
|
|
|
|
if (value.is_table()) {
|
|
|
|
for (auto&& [nested_key, nested_value] : *value.as_table()) {
|
|
|
|
/* clang-format off */
|
|
|
|
if (!nested_value.is_table()) { continue; }
|
|
|
|
/* clang-format on */
|
|
|
|
|
|
|
|
const auto& nested_profile_name = fmt::format(FMT_COMPILE("{}.{}"), std::string_view{key}, std::string_view{nested_key});
|
|
|
|
profile_names.push_back(nested_profile_name);
|
|
|
|
}
|
2024-06-27 05:40:56 +08:00
|
|
|
profile_names.emplace_back(key);
|
2023-07-01 03:45:33 +08:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
return profile_names;
|
|
|
|
}
|
|
|
|
|
|
|
|
auto get_available_profile_names(std::string_view profile_type) noexcept -> std::optional<std::vector<std::string>> {
|
|
|
|
auto&& all_profile_names = get_all_profile_names(profile_type);
|
|
|
|
/* clang-format off */
|
|
|
|
if (!all_profile_names.has_value()) { return {}; }
|
|
|
|
/* clang-format on */
|
|
|
|
|
2024-06-26 20:54:04 +08:00
|
|
|
const auto& available_profile_names = gucc::utils::make_multiline(gucc::utils::exec("chwd --list -d | grep Name | awk '{print $4}'"));
|
2023-07-01 03:45:33 +08:00
|
|
|
|
|
|
|
std::vector<std::string> filtered_profile_names{};
|
2024-07-13 08:24:37 +08:00
|
|
|
const auto& functor = [available_profile_names](auto&& profile_name) { return std::ranges::contains(available_profile_names, profile_name); };
|
2023-07-01 03:45:33 +08:00
|
|
|
|
2024-07-13 08:24:37 +08:00
|
|
|
const auto& for_each_functor = [&](auto&& rng) { filtered_profile_names.push_back(std::forward<decltype(rng)>(rng)); };
|
|
|
|
std::ranges::for_each(all_profile_names.value() | std::ranges::views::filter(functor), for_each_functor);
|
2023-07-01 03:45:33 +08:00
|
|
|
return filtered_profile_names;
|
|
|
|
}
|
|
|
|
|
|
|
|
} // namespace detail::chwd
|