mirror of
https://github.com/HamletDuFromage/aio-switch-updater.git
synced 2025-01-01 12:16:02 +00:00
add a prompt asking about replacing reboot_payload.bin by hekate (closes https://github.com/HamletDuFromage/aio-switch-updater/issues/153)
This commit is contained in:
parent
cc50d526c0
commit
cb6b78c11c
5 changed files with 39 additions and 57 deletions
|
@ -2,6 +2,7 @@
|
||||||
|
|
||||||
#include <switch.h>
|
#include <switch.h>
|
||||||
|
|
||||||
|
#include <functional>
|
||||||
#include <set>
|
#include <set>
|
||||||
#include <string>
|
#include <string>
|
||||||
#include <vector>
|
#include <vector>
|
||||||
|
@ -25,8 +26,8 @@ namespace extract {
|
||||||
}
|
}
|
||||||
} Title;
|
} Title;
|
||||||
|
|
||||||
void extract(const std::string& filename, const std::string& workingPath = ROOT_PATH, int overwriteInis = 1);
|
void extract(
|
||||||
void extract(const std::string& filename, const std::string& workingPath, const std::string& toExclude);
|
const std::string& filename, const std::string& workingPath = ROOT_PATH, int overwriteInis = 1, std::function<void()> func = []() { return; });
|
||||||
std::vector<std::string> getInstalledTitlesNs();
|
std::vector<std::string> getInstalledTitlesNs();
|
||||||
std::vector<std::string> excludeTitles(const std::string& path, const std::vector<std::string>& listedTitles);
|
std::vector<std::string> excludeTitles(const std::string& path, const std::vector<std::string>& listedTitles);
|
||||||
void writeTitlesToFile(const std::set<std::string>& titles, const std::string& path);
|
void writeTitlesToFile(const std::set<std::string>& titles, const std::string& path);
|
||||||
|
|
|
@ -9,17 +9,17 @@ class ListDownloadTab : public brls::List
|
||||||
{
|
{
|
||||||
private:
|
private:
|
||||||
brls::ListItem* listItem;
|
brls::ListItem* listItem;
|
||||||
brls::ListItem* cheatslipsItem;
|
|
||||||
brls::ListItem* gbatempItem;
|
|
||||||
nlohmann::ordered_json nxlinks;
|
nlohmann::ordered_json nxlinks;
|
||||||
std::string currentCheatsVer = "";
|
std::string currentCheatsVer = "";
|
||||||
std::string newCheatsVer = "";
|
std::string newCheatsVer = "";
|
||||||
contentType type;
|
contentType type;
|
||||||
int size = 0;
|
int size = 0;
|
||||||
|
void createList();
|
||||||
void createList(contentType type);
|
void createList(contentType type);
|
||||||
void createCheatSlipItem();
|
void createCheatSlipItem();
|
||||||
void creategbatempItem();
|
void creategbatempItem();
|
||||||
void setDescription();
|
void setDescription();
|
||||||
|
void setDescription(contentType type);
|
||||||
void displayNotFound();
|
void displayNotFound();
|
||||||
|
|
||||||
public:
|
public:
|
||||||
|
|
|
@ -165,7 +165,9 @@
|
||||||
"fw_warning": "Because of the size of the FW archive, downloading firmwares in Applet Mode is not supported. Please launch the app with full RAM access.",
|
"fw_warning": "Because of the size of the FW archive, downloading firmwares in Applet Mode is not supported. Please launch the app with full RAM access.",
|
||||||
"overwrite": " Do you want to overwrite existing ",
|
"overwrite": " Do you want to overwrite existing ",
|
||||||
"not_an_archive": "The downloaded file is not a zip archive. This is most likely due to a broken link. If the problem persists after more than 30 minutes, please open an issue on Github.",
|
"not_an_archive": "The downloaded file is not a zip archive. This is most likely due to a broken link. If the problem persists after more than 30 minutes, please open an issue on Github.",
|
||||||
"overwrite_inis": "Do you want to overwrite existing .ini config files?"
|
"overwrite_inis": "Do you want to overwrite existing .ini config files?",
|
||||||
|
"set_hekate_reboot_payload": "Do you want to copy the Hekate payload `{}` to `{}`?"
|
||||||
|
|
||||||
},
|
},
|
||||||
"ams_update": {
|
"ams_update": {
|
||||||
"reboot_rcm": "The Switch will now reboot to a special payload in order to finalise the install.",
|
"reboot_rcm": "The Switch will now reboot to a special payload in order to finalise the install.",
|
||||||
|
|
|
@ -47,12 +47,12 @@ namespace extract {
|
||||||
brls::Application::quit();
|
brls::Application::quit();
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
ProgressEvent::instance().setStep(1);
|
|
||||||
ProgressEvent::instance().setTotalSteps(entries.size() + 1);
|
ProgressEvent::instance().setTotalSteps(entries.size() + 1);
|
||||||
|
ProgressEvent::instance().setStep(0);
|
||||||
}
|
}
|
||||||
} // namespace
|
} // namespace
|
||||||
|
|
||||||
void extract(const std::string& filename, const std::string& workingPath, int overwriteInis)
|
void extract(const std::string& filename, const std::string& workingPath, int overwriteInis, std::function<void()> func)
|
||||||
{
|
{
|
||||||
zipper::Unzipper unzipper(filename);
|
zipper::Unzipper unzipper(filename);
|
||||||
std::vector<zipper::ZipEntry> entries;
|
std::vector<zipper::ZipEntry> entries;
|
||||||
|
@ -71,7 +71,7 @@ namespace extract {
|
||||||
unzipper.extractEntry(entry.name);
|
unzipper.extractEntry(entry.name);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
else if (entry.name == "sept/payload.bin" || entry.name == "atmosphere/fusee-secondary.bin" || entry.name == "atmosphere/stratosphere.romfs" || entry.name == "atmosphere/package3") {
|
else if (entry.name == "atmosphere/stratosphere.romfs" || entry.name == "atmosphere/package3") {
|
||||||
std::ofstream readonlyFile(entry.name + ".aio");
|
std::ofstream readonlyFile(entry.name + ".aio");
|
||||||
unzipper.extractEntryToStream(entry.name, readonlyFile);
|
unzipper.extractEntryToStream(entry.name, readonlyFile);
|
||||||
}
|
}
|
||||||
|
@ -79,7 +79,9 @@ namespace extract {
|
||||||
unzipper.extractEntry(entry.name);
|
unzipper.extractEntry(entry.name);
|
||||||
if (entry.name.substr(0, 13) == "hekate_ctcaer") {
|
if (entry.name.substr(0, 13) == "hekate_ctcaer") {
|
||||||
fs::copyFile("/" + entry.name, UPDATE_BIN_PATH);
|
fs::copyFile("/" + entry.name, UPDATE_BIN_PATH);
|
||||||
fs::copyFile("/" + entry.name, REBOOT_PAYLOAD_PATH);
|
if (util::showDialogBox(fmt::format("menus/utils/set_hekate_reboot_payload"_i18n, UPDATE_BIN_PATH, REBOOT_PAYLOAD_PATH), "menus/common/yes"_i18n, "menus/common/no"_i18n) == 0) {
|
||||||
|
fs::copyFile(UPDATE_BIN_PATH, REBOOT_PAYLOAD_PATH);
|
||||||
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
ProgressEvent::instance().incrementStep(1);
|
ProgressEvent::instance().incrementStep(1);
|
||||||
|
@ -88,35 +90,6 @@ namespace extract {
|
||||||
ProgressEvent::instance().setStep(ProgressEvent::instance().getMax());
|
ProgressEvent::instance().setStep(ProgressEvent::instance().getMax());
|
||||||
}
|
}
|
||||||
|
|
||||||
void extract(const std::string& filename, const std::string& workingPath, const std::string& toExclude)
|
|
||||||
{
|
|
||||||
zipper::Unzipper unzipper(filename);
|
|
||||||
std::vector<zipper::ZipEntry> entries;
|
|
||||||
preWork(unzipper, workingPath, entries);
|
|
||||||
|
|
||||||
std::set<std::string> ignoreList = fs::readLineByLine(FILES_IGNORE);
|
|
||||||
ignoreList.insert(toExclude);
|
|
||||||
|
|
||||||
for (const auto& entry : entries) {
|
|
||||||
if (ProgressEvent::instance().getInterupt()) {
|
|
||||||
break;
|
|
||||||
}
|
|
||||||
if (find_if(ignoreList.begin(), ignoreList.end(), [&entry](std::string ignored) {
|
|
||||||
u8 res = ("/" + entry.name).find(ignored);
|
|
||||||
return (res == 0 || res == 1); }) != ignoreList.end()) {
|
|
||||||
if (!std::filesystem::exists("/" + entry.name)) {
|
|
||||||
unzipper.extractEntry(entry.name);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
else {
|
|
||||||
unzipper.extractEntry(entry.name);
|
|
||||||
}
|
|
||||||
ProgressEvent::instance().incrementStep(1);
|
|
||||||
}
|
|
||||||
unzipper.close();
|
|
||||||
ProgressEvent::instance().setStep(ProgressEvent::instance().getMax());
|
|
||||||
}
|
|
||||||
|
|
||||||
std::vector<std::string> getInstalledTitlesNs()
|
std::vector<std::string> getInstalledTitlesNs()
|
||||||
{
|
{
|
||||||
std::vector<std::string> titles;
|
std::vector<std::string> titles;
|
||||||
|
|
|
@ -21,7 +21,7 @@ ListDownloadTab::ListDownloadTab(const contentType type, const nlohmann::ordered
|
||||||
{
|
{
|
||||||
this->setDescription();
|
this->setDescription();
|
||||||
|
|
||||||
this->createList(this->type);
|
this->createList();
|
||||||
|
|
||||||
if (this->type == contentType::cheats) {
|
if (this->type == contentType::cheats) {
|
||||||
brls::Label* cheatsLabel = new brls::Label(
|
brls::Label* cheatsLabel = new brls::Label(
|
||||||
|
@ -29,24 +29,24 @@ ListDownloadTab::ListDownloadTab(const contentType type, const nlohmann::ordered
|
||||||
"menus/cheats/cheats_label"_i18n,
|
"menus/cheats/cheats_label"_i18n,
|
||||||
true);
|
true);
|
||||||
this->addView(cheatsLabel);
|
this->addView(cheatsLabel);
|
||||||
creategbatempItem();
|
this->creategbatempItem();
|
||||||
createCheatSlipItem();
|
this->createCheatSlipItem();
|
||||||
}
|
}
|
||||||
|
|
||||||
if (this->type == contentType::bootloaders) {
|
if (this->type == contentType::bootloaders) {
|
||||||
brls::Label* payloadsLabel = new brls::Label(
|
this->setDescription(contentType::payloads);
|
||||||
brls::LabelStyle::DESCRIPTION,
|
this->createList(contentType::payloads);
|
||||||
fmt::format("menus/main/payloads_label"_i18n, BOOTLOADER_PL_PATH),
|
|
||||||
true);
|
|
||||||
this->addView(payloadsLabel);
|
|
||||||
createList(contentType::payloads);
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
void ListDownloadTab::createList() {
|
||||||
|
ListDownloadTab::createList(this->type);
|
||||||
|
}
|
||||||
|
|
||||||
void ListDownloadTab::createList(contentType type)
|
void ListDownloadTab::createList(contentType type)
|
||||||
{
|
{
|
||||||
std::vector<std::pair<std::string, std::string>> links;
|
std::vector<std::pair<std::string, std::string>> links;
|
||||||
if (this->type == contentType::cheats && this->newCheatsVer != "")
|
if (type == contentType::cheats && this->newCheatsVer != "")
|
||||||
links.push_back(std::make_pair(fmt::format("{}{})", "menus/main/get_cheats"_i18n, this->newCheatsVer), CurrentCfw::running_cfw == CFW::sxos ? CHEATS_URL_TITLES : CHEATS_URL_CONTENTS));
|
links.push_back(std::make_pair(fmt::format("{}{})", "menus/main/get_cheats"_i18n, this->newCheatsVer), CurrentCfw::running_cfw == CFW::sxos ? CHEATS_URL_TITLES : CHEATS_URL_CONTENTS));
|
||||||
else
|
else
|
||||||
links = download::getLinksFromJson(util::getValueFromKey(this->nxlinks, contentTypeNames[(int)type].data()));
|
links = download::getLinksFromJson(util::getValueFromKey(this->nxlinks, contentTypeNames[(int)type].data()));
|
||||||
|
@ -58,15 +58,15 @@ void ListDownloadTab::createList(contentType type)
|
||||||
const std::string text("menus/common/download"_i18n + link.first + "menus/common/from"_i18n + url);
|
const std::string text("menus/common/download"_i18n + link.first + "menus/common/from"_i18n + url);
|
||||||
listItem = new brls::ListItem(link.first);
|
listItem = new brls::ListItem(link.first);
|
||||||
listItem->setHeight(LISTITEM_HEIGHT);
|
listItem->setHeight(LISTITEM_HEIGHT);
|
||||||
listItem->getClickEvent()->subscribe([this, text, url, title, type](brls::View* view) {
|
listItem->getClickEvent()->subscribe([this, type, text, url, title](brls::View* view) {
|
||||||
brls::StagedAppletFrame* stagedFrame = new brls::StagedAppletFrame();
|
brls::StagedAppletFrame* stagedFrame = new brls::StagedAppletFrame();
|
||||||
stagedFrame->setTitle(fmt::format("menus/main/getting"_i18n, contentTypeNames[(int)type].data()));
|
stagedFrame->setTitle(fmt::format("menus/main/getting"_i18n, contentTypeNames[(int)type].data()));
|
||||||
stagedFrame->addStage(new ConfirmPage(stagedFrame, text));
|
stagedFrame->addStage(new ConfirmPage(stagedFrame, text));
|
||||||
if (type != contentType::payloads) {
|
if (type != contentType::payloads) {
|
||||||
if (type != contentType::cheats || this->newCheatsVer != this->currentCheatsVer || !std::filesystem::exists(CHEATS_ZIP_PATH)) {
|
if (type != contentType::cheats || this->newCheatsVer != this->currentCheatsVer || !std::filesystem::exists(CHEATS_ZIP_PATH)) {
|
||||||
stagedFrame->addStage(new WorkerPage(stagedFrame, "menus/common/downloading"_i18n, [type, url]() { util::downloadArchive(url, type); }));
|
stagedFrame->addStage(new WorkerPage(stagedFrame, "menus/common/downloading"_i18n, [this, type, url]() { util::downloadArchive(url, type); }));
|
||||||
}
|
}
|
||||||
stagedFrame->addStage(new WorkerPage(stagedFrame, "menus/common/extracting"_i18n, [type]() { util::extractArchive(type); }));
|
stagedFrame->addStage(new WorkerPage(stagedFrame, "menus/common/extracting"_i18n, [this, type]() { util::extractArchive(type); }));
|
||||||
}
|
}
|
||||||
else {
|
else {
|
||||||
fs::createTree(BOOTLOADER_PL_PATH);
|
fs::createTree(BOOTLOADER_PL_PATH);
|
||||||
|
@ -121,13 +121,17 @@ void ListDownloadTab::displayNotFound()
|
||||||
}
|
}
|
||||||
|
|
||||||
void ListDownloadTab::setDescription()
|
void ListDownloadTab::setDescription()
|
||||||
|
{
|
||||||
|
this->setDescription(this->type);
|
||||||
|
}
|
||||||
|
|
||||||
|
void ListDownloadTab::setDescription(contentType type)
|
||||||
{
|
{
|
||||||
brls::Label* description = new brls::Label(brls::LabelStyle::DESCRIPTION, "", true);
|
brls::Label* description = new brls::Label(brls::LabelStyle::DESCRIPTION, "", true);
|
||||||
|
|
||||||
switch (this->type) {
|
switch (type) {
|
||||||
case contentType::sigpatches:
|
case contentType::sigpatches:
|
||||||
description->setText(
|
description->setText("menus/main/sigpatches_text"_i18n);
|
||||||
"menus/main/sigpatches_text"_i18n);
|
|
||||||
break;
|
break;
|
||||||
case contentType::fw: {
|
case contentType::fw: {
|
||||||
SetSysFirmwareVersion ver;
|
SetSysFirmwareVersion ver;
|
||||||
|
@ -139,11 +143,13 @@ void ListDownloadTab::setDescription()
|
||||||
"menus/main/bootloaders_text"_i18n);
|
"menus/main/bootloaders_text"_i18n);
|
||||||
break;
|
break;
|
||||||
case contentType::cheats:
|
case contentType::cheats:
|
||||||
|
|
||||||
this->newCheatsVer = util::downloadFileToString(CHEATS_URL_VERSION);
|
this->newCheatsVer = util::downloadFileToString(CHEATS_URL_VERSION);
|
||||||
this->currentCheatsVer = util::readVersion(CHEATS_VERSION);
|
this->currentCheatsVer = util::readVersion(CHEATS_VERSION);
|
||||||
description->setText("menus/main/cheats_text"_i18n + this->currentCheatsVer);
|
description->setText("menus/main/cheats_text"_i18n + this->currentCheatsVer);
|
||||||
break;
|
break;
|
||||||
|
case contentType::payloads:
|
||||||
|
description->setText("menus/main/payloads_label"_i18n);
|
||||||
|
break;
|
||||||
default:
|
default:
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
|
@ -153,7 +159,7 @@ void ListDownloadTab::setDescription()
|
||||||
|
|
||||||
void ListDownloadTab::createCheatSlipItem()
|
void ListDownloadTab::createCheatSlipItem()
|
||||||
{
|
{
|
||||||
cheatslipsItem = new brls::ListItem("menus/cheats/get_cheatslips"_i18n);
|
brls::ListItem* cheatslipsItem = new brls::ListItem("menus/cheats/get_cheatslips"_i18n);
|
||||||
cheatslipsItem->setHeight(LISTITEM_HEIGHT);
|
cheatslipsItem->setHeight(LISTITEM_HEIGHT);
|
||||||
cheatslipsItem->getClickEvent()->subscribe([](brls::View* view) {
|
cheatslipsItem->getClickEvent()->subscribe([](brls::View* view) {
|
||||||
if (std::filesystem::exists(TOKEN_PATH)) {
|
if (std::filesystem::exists(TOKEN_PATH)) {
|
||||||
|
@ -196,7 +202,7 @@ void ListDownloadTab::createCheatSlipItem()
|
||||||
|
|
||||||
void ListDownloadTab::creategbatempItem()
|
void ListDownloadTab::creategbatempItem()
|
||||||
{
|
{
|
||||||
gbatempItem = new brls::ListItem("menus/cheats/get_gbatemp"_i18n);
|
brls::ListItem* gbatempItem = new brls::ListItem("menus/cheats/get_gbatemp"_i18n);
|
||||||
gbatempItem->setHeight(LISTITEM_HEIGHT);
|
gbatempItem->setHeight(LISTITEM_HEIGHT);
|
||||||
gbatempItem->getClickEvent()->subscribe([](brls::View* view) {
|
gbatempItem->getClickEvent()->subscribe([](brls::View* view) {
|
||||||
brls::Application::pushView(new AppPage_Gbatemp());
|
brls::Application::pushView(new AppPage_Gbatemp());
|
||||||
|
|
Loading…
Reference in a new issue