Added ReloadConfig

This commit is contained in:
acidicoala
2023-01-11 01:35:14 +03:00
parent 30f1076261
commit edd785cfcf
21 changed files with 184 additions and 128 deletions

View File

@@ -13,25 +13,34 @@ namespace smoke_api::config {
if (exists(path)) {
try {
instance = Json::parse(koalabox::io::read_file(path)).get<Config>();
const auto config_str = koalabox::io::read_file(path);
LOG_DEBUG("Parsing config:\n{}", config_str)
instance = Json::parse(config_str).get<Config>();
} catch (const Exception& e) {
koalabox::util::panic("Error parsing config: {}", e.what());
const auto message = fmt::format("Error parsing config file: {}", e.what());
koalabox::util::error_box("SmokeAPI Error", message);
}
}
}
bool is_dlc_unlocked(AppId_t app_id, AppId_t dlc_id, const Function<bool()>& original_function) {
const auto app_id_str = std::to_string(app_id);
const auto dlc_id_str = std::to_string(dlc_id);
Vector<DLC> get_extra_dlcs(AppId_t app_id) {
return DLC::get_dlcs_from_apps(instance.extra_dlcs, app_id);
}
bool is_dlc_unlocked(AppId_t app_id, AppId_t dlc_id, const Function<bool()>& original_function) {
auto status = instance.default_app_status;
const auto app_id_str = std::to_string(app_id);
if (instance.override_app_status.contains(app_id_str)) {
status = instance.override_app_status[app_id_str];
}
if (instance.override_app_status.contains(dlc_id_str)) {
status = instance.override_app_status[dlc_id_str];
const auto dlc_id_str = std::to_string(dlc_id);
if (instance.override_dlc_status.contains(dlc_id_str)) {
status = instance.override_dlc_status[dlc_id_str];
}
bool is_unlocked;
@@ -47,15 +56,18 @@ namespace smoke_api::config {
is_unlocked = original_function();
break;
}
LOG_TRACE(
"App ID: {}, DLC ID: {}, Status: {}, Original: {}, Is Unlocked: {}",
"App ID: {}, DLC ID: {}, Status: {}, Original: {}, Unlocked: {}",
app_id_str, dlc_id_str, Json(status).dump(), original_function(), is_unlocked
)
return is_unlocked;
}
Vector<DLC> get_extra_dlcs(AppId_t app_id) {
return DLC::get_dlcs_from_apps(instance.extra_dlcs, app_id);
DLL_EXPORT(void) ReloadConfig() {
LOG_INFO("Reloading config")
init();
}
}

View File

@@ -25,6 +25,7 @@ namespace smoke_api::config {
bool unlock_family_sharing = true;
AppStatus default_app_status = AppStatus::UNLOCKED;
Map<String, AppStatus> override_app_status;
Map<String, AppStatus> override_dlc_status;
AppDlcNameMap extra_dlcs;
bool auto_inject_inventory = true;
Vector<uint32_t> extra_inventory_items;
@@ -38,6 +39,7 @@ namespace smoke_api::config {
unlock_family_sharing,
default_app_status,
override_app_status,
override_dlc_status,
extra_dlcs,
auto_inject_inventory,
extra_inventory_items,
@@ -49,7 +51,7 @@ namespace smoke_api::config {
void init();
bool is_dlc_unlocked(uint32_t app_id, uint32_t dlc_id, const Function<bool()>& original_function);
Vector<DLC> get_extra_dlcs(AppId_t app_id);
bool is_dlc_unlocked(uint32_t app_id, uint32_t dlc_id, const Function<bool()>& original_function);
}

View File

@@ -128,4 +128,5 @@ namespace smoke_api {
LOG_ERROR("Shutdown error: {}", ex.what())
}
}
}