forked from eden-emu/eden
		
	Create a random console_unique_id (#2668)
* Create a random console_id when config save_file is created Added button in system config to refresh the console unique id * Moved the connect for the button from .ui file to constructor of ConfigureSystem * Added warning and info dialog Fixup: Make use of qt5 style connects, renamed the refresh button, removed some duplicate code, changed random device and moved all to the generate function * Changed the random generator to reflect what a real 3DS stores as console unique id Fixup: Changed the warning message * Fixup: Set and Create * Fixup: Added console id label, therfore removed second message box * Fixup: fixed the endianess * Fixup: more endianness fixes * Fixup: Endianness the 3rd
This commit is contained in:
		
							parent
							
								
									4906d0617c
								
							
						
					
					
						commit
						e719319b10
					
				
					 5 changed files with 123 additions and 7 deletions
				
			
		|  | @ -2,6 +2,7 @@ | ||||||
| // Licensed under GPLv2 or any later version
 | // Licensed under GPLv2 or any later version
 | ||||||
| // Refer to the license.txt file included.
 | // Refer to the license.txt file included.
 | ||||||
| 
 | 
 | ||||||
|  | #include <QMessageBox> | ||||||
| #include "citra_qt/configuration/configure_system.h" | #include "citra_qt/configuration/configure_system.h" | ||||||
| #include "citra_qt/ui_settings.h" | #include "citra_qt/ui_settings.h" | ||||||
| #include "core/core.h" | #include "core/core.h" | ||||||
|  | @ -15,8 +16,11 @@ static const std::array<int, 12> days_in_month = {{ | ||||||
| 
 | 
 | ||||||
| ConfigureSystem::ConfigureSystem(QWidget* parent) : QWidget(parent), ui(new Ui::ConfigureSystem) { | ConfigureSystem::ConfigureSystem(QWidget* parent) : QWidget(parent), ui(new Ui::ConfigureSystem) { | ||||||
|     ui->setupUi(this); |     ui->setupUi(this); | ||||||
|     connect(ui->combo_birthmonth, SIGNAL(currentIndexChanged(int)), |     connect(ui->combo_birthmonth, | ||||||
|             SLOT(updateBirthdayComboBox(int))); |             static_cast<void (QComboBox::*)(int)>(&QComboBox::currentIndexChanged), this, | ||||||
|  |             &ConfigureSystem::updateBirthdayComboBox); | ||||||
|  |     connect(ui->button_regenerate_console_id, &QPushButton::clicked, this, | ||||||
|  |             &ConfigureSystem::refreshConsoleID); | ||||||
| 
 | 
 | ||||||
|     this->setConfiguration(); |     this->setConfiguration(); | ||||||
| } | } | ||||||
|  | @ -71,6 +75,10 @@ void ConfigureSystem::ReadSystemSettings() { | ||||||
|     // set sound output mode
 |     // set sound output mode
 | ||||||
|     sound_index = Service::CFG::GetSoundOutputMode(); |     sound_index = Service::CFG::GetSoundOutputMode(); | ||||||
|     ui->combo_sound->setCurrentIndex(sound_index); |     ui->combo_sound->setCurrentIndex(sound_index); | ||||||
|  | 
 | ||||||
|  |     // set the console id
 | ||||||
|  |     u64 console_id = Service::CFG::GetConsoleUniqueId(); | ||||||
|  |     ui->label_console_id->setText("Console ID: 0x" + QString::number(console_id, 16).toUpper()); | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
| void ConfigureSystem::applyConfiguration() { | void ConfigureSystem::applyConfiguration() { | ||||||
|  | @ -140,3 +148,21 @@ void ConfigureSystem::updateBirthdayComboBox(int birthmonth_index) { | ||||||
|     // restore the day selection
 |     // restore the day selection
 | ||||||
|     ui->combo_birthday->setCurrentIndex(birthday_index); |     ui->combo_birthday->setCurrentIndex(birthday_index); | ||||||
| } | } | ||||||
|  | 
 | ||||||
|  | void ConfigureSystem::refreshConsoleID() { | ||||||
|  |     QMessageBox::StandardButton reply; | ||||||
|  |     QString warning_text = tr("This will replace your current virtual 3DS with a new one. " | ||||||
|  |                               "Your current virtual 3DS will not be recoverable. " | ||||||
|  |                               "This might have unexpected effects in games. This might fail, " | ||||||
|  |                               "if you use an outdated config savegame. Continue?"); | ||||||
|  |     reply = QMessageBox::critical(this, tr("Warning"), warning_text, | ||||||
|  |                                   QMessageBox::No | QMessageBox::Yes); | ||||||
|  |     if (reply == QMessageBox::No) | ||||||
|  |         return; | ||||||
|  |     u32 random_number; | ||||||
|  |     u64 console_id; | ||||||
|  |     Service::CFG::GenerateConsoleUniqueId(random_number, console_id); | ||||||
|  |     Service::CFG::SetConsoleUniqueId(random_number, console_id); | ||||||
|  |     Service::CFG::UpdateConfigNANDSavegame(); | ||||||
|  |     ui->label_console_id->setText("Console ID: 0x" + QString::number(console_id, 16).toUpper()); | ||||||
|  | } | ||||||
|  |  | ||||||
|  | @ -23,6 +23,7 @@ public: | ||||||
| 
 | 
 | ||||||
| public slots: | public slots: | ||||||
|     void updateBirthdayComboBox(int birthmonth_index); |     void updateBirthdayComboBox(int birthmonth_index); | ||||||
|  |     void refreshConsoleID(); | ||||||
| 
 | 
 | ||||||
| private: | private: | ||||||
|     void ReadSystemSettings(); |     void ReadSystemSettings(); | ||||||
|  |  | ||||||
|  | @ -220,6 +220,29 @@ | ||||||
|           </item> |           </item> | ||||||
|          </widget> |          </widget> | ||||||
|         </item> |         </item> | ||||||
|  |         <item row="4" column="0"> | ||||||
|  |          <widget class="QLabel" name="label_console_id"> | ||||||
|  |           <property name="text"> | ||||||
|  |            <string>Console ID:</string> | ||||||
|  |           </property> | ||||||
|  |          </widget> | ||||||
|  |         </item> | ||||||
|  |         <item row="4" column="1"> | ||||||
|  |          <widget class="QPushButton" name="button_regenerate_console_id"> | ||||||
|  |           <property name="sizePolicy"> | ||||||
|  |            <sizepolicy hsizetype="Fixed" vsizetype="Fixed"> | ||||||
|  |             <horstretch>0</horstretch> | ||||||
|  |             <verstretch>0</verstretch> | ||||||
|  |            </sizepolicy> | ||||||
|  |           </property> | ||||||
|  |           <property name="layoutDirection"> | ||||||
|  |            <enum>Qt::RightToLeft</enum> | ||||||
|  |           </property> | ||||||
|  |           <property name="text"> | ||||||
|  |            <string>Regenerate</string> | ||||||
|  |           </property> | ||||||
|  |          </widget> | ||||||
|  |         </item> | ||||||
|        </layout> |        </layout> | ||||||
|       </widget> |       </widget> | ||||||
|      </item> |      </item> | ||||||
|  |  | ||||||
|  | @ -4,6 +4,7 @@ | ||||||
| 
 | 
 | ||||||
| #include <algorithm> | #include <algorithm> | ||||||
| #include <array> | #include <array> | ||||||
|  | #include <cryptopp/osrng.h> | ||||||
| #include <cryptopp/sha.h> | #include <cryptopp/sha.h> | ||||||
| #include "common/file_util.h" | #include "common/file_util.h" | ||||||
| #include "common/logging/log.h" | #include "common/logging/log.h" | ||||||
|  | @ -50,6 +51,7 @@ enum ConfigBlockID { | ||||||
|     SoundOutputModeBlockID = 0x00070001, |     SoundOutputModeBlockID = 0x00070001, | ||||||
|     ConsoleUniqueID1BlockID = 0x00090000, |     ConsoleUniqueID1BlockID = 0x00090000, | ||||||
|     ConsoleUniqueID2BlockID = 0x00090001, |     ConsoleUniqueID2BlockID = 0x00090001, | ||||||
|  |     ConsoleUniqueID3BlockID = 0x00090002, | ||||||
|     UsernameBlockID = 0x000A0000, |     UsernameBlockID = 0x000A0000, | ||||||
|     BirthdayBlockID = 0x000A0001, |     BirthdayBlockID = 0x000A0001, | ||||||
|     LanguageBlockID = 0x000A0002, |     LanguageBlockID = 0x000A0002, | ||||||
|  | @ -86,7 +88,6 @@ struct ConsoleCountryInfo { | ||||||
| static_assert(sizeof(ConsoleCountryInfo) == 4, "ConsoleCountryInfo must be exactly 4 bytes"); | static_assert(sizeof(ConsoleCountryInfo) == 4, "ConsoleCountryInfo must be exactly 4 bytes"); | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
| static const u64 CONSOLE_UNIQUE_ID = 0xDEADC0DE; |  | ||||||
| static const ConsoleModelInfo CONSOLE_MODEL = {NINTENDO_3DS_XL, {0, 0, 0}}; | static const ConsoleModelInfo CONSOLE_MODEL = {NINTENDO_3DS_XL, {0, 0, 0}}; | ||||||
| static const u8 CONSOLE_LANGUAGE = LANGUAGE_EN; | static const u8 CONSOLE_LANGUAGE = LANGUAGE_EN; | ||||||
| static const UsernameBlock CONSOLE_USERNAME_BLOCK = {u"CITRA", 0, 0}; | static const UsernameBlock CONSOLE_USERNAME_BLOCK = {u"CITRA", 0, 0}; | ||||||
|  | @ -438,13 +439,22 @@ ResultCode FormatConfig() { | ||||||
|     if (!res.IsSuccess()) |     if (!res.IsSuccess()) | ||||||
|         return res; |         return res; | ||||||
| 
 | 
 | ||||||
|     res = CreateConfigInfoBlk(ConsoleUniqueID1BlockID, sizeof(CONSOLE_UNIQUE_ID), 0xE, |     u32 random_number; | ||||||
|                               &CONSOLE_UNIQUE_ID); |     u64 console_id; | ||||||
|  |     GenerateConsoleUniqueId(random_number, console_id); | ||||||
|  | 
 | ||||||
|  |     u64_le console_id_le = console_id; | ||||||
|  |     res = CreateConfigInfoBlk(ConsoleUniqueID1BlockID, sizeof(console_id_le), 0xE, &console_id_le); | ||||||
|     if (!res.IsSuccess()) |     if (!res.IsSuccess()) | ||||||
|         return res; |         return res; | ||||||
| 
 | 
 | ||||||
|     res = CreateConfigInfoBlk(ConsoleUniqueID2BlockID, sizeof(CONSOLE_UNIQUE_ID), 0xE, |     res = CreateConfigInfoBlk(ConsoleUniqueID2BlockID, sizeof(console_id_le), 0xE, &console_id_le); | ||||||
|                               &CONSOLE_UNIQUE_ID); |     if (!res.IsSuccess()) | ||||||
|  |         return res; | ||||||
|  | 
 | ||||||
|  |     u32_le random_number_le = random_number; | ||||||
|  |     res = CreateConfigInfoBlk(ConsoleUniqueID3BlockID, sizeof(random_number_le), 0xE, | ||||||
|  |                               &random_number_le); | ||||||
|     if (!res.IsSuccess()) |     if (!res.IsSuccess()) | ||||||
|         return res; |         return res; | ||||||
| 
 | 
 | ||||||
|  | @ -663,5 +673,40 @@ SoundOutputMode GetSoundOutputMode() { | ||||||
|     return static_cast<SoundOutputMode>(block); |     return static_cast<SoundOutputMode>(block); | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
|  | void GenerateConsoleUniqueId(u32& random_number, u64& console_id) { | ||||||
|  |     CryptoPP::AutoSeededRandomPool rng; | ||||||
|  |     random_number = rng.GenerateWord32(0, 0xFFFF); | ||||||
|  |     u64_le local_friend_code_seed; | ||||||
|  |     rng.GenerateBlock(reinterpret_cast<byte*>(&local_friend_code_seed), | ||||||
|  |                       sizeof(local_friend_code_seed)); | ||||||
|  |     console_id = (local_friend_code_seed & 0x3FFFFFFFF) | (static_cast<u64>(random_number) << 48); | ||||||
|  | } | ||||||
|  | 
 | ||||||
|  | ResultCode SetConsoleUniqueId(u32 random_number, u64 console_id) { | ||||||
|  |     u64_le console_id_le = console_id; | ||||||
|  |     ResultCode res = | ||||||
|  |         SetConfigInfoBlock(ConsoleUniqueID1BlockID, sizeof(console_id_le), 0xE, &console_id_le); | ||||||
|  |     if (!res.IsSuccess()) | ||||||
|  |         return res; | ||||||
|  | 
 | ||||||
|  |     res = SetConfigInfoBlock(ConsoleUniqueID2BlockID, sizeof(console_id_le), 0xE, &console_id_le); | ||||||
|  |     if (!res.IsSuccess()) | ||||||
|  |         return res; | ||||||
|  | 
 | ||||||
|  |     u32_le random_number_le = random_number; | ||||||
|  |     res = SetConfigInfoBlock(ConsoleUniqueID3BlockID, sizeof(random_number_le), 0xE, | ||||||
|  |                              &random_number_le); | ||||||
|  |     if (!res.IsSuccess()) | ||||||
|  |         return res; | ||||||
|  | 
 | ||||||
|  |     return RESULT_SUCCESS; | ||||||
|  | } | ||||||
|  | 
 | ||||||
|  | u64 GetConsoleUniqueId() { | ||||||
|  |     u64_le console_id_le; | ||||||
|  |     GetConfigInfoBlock(ConsoleUniqueID2BlockID, sizeof(console_id_le), 0xE, &console_id_le); | ||||||
|  |     return console_id_le; | ||||||
|  | } | ||||||
|  | 
 | ||||||
| } // namespace CFG
 | } // namespace CFG
 | ||||||
| } // namespace Service
 | } // namespace Service
 | ||||||
|  |  | ||||||
|  | @ -342,5 +342,26 @@ void SetSoundOutputMode(SoundOutputMode mode); | ||||||
|  */ |  */ | ||||||
| SoundOutputMode GetSoundOutputMode(); | SoundOutputMode GetSoundOutputMode(); | ||||||
| 
 | 
 | ||||||
|  | /**
 | ||||||
|  |  * Generates a new random console unique id. | ||||||
|  |  * @param random_number a random generated 16bit number stored at 0x90002, used for generating the | ||||||
|  |  * console_id | ||||||
|  |  * @param console_id the randomly created console id | ||||||
|  |  */ | ||||||
|  | void GenerateConsoleUniqueId(u32& random_number, u64& console_id); | ||||||
|  | 
 | ||||||
|  | /**
 | ||||||
|  |  * Sets the random_number and the  console unique id in the config savegame. | ||||||
|  |  * @param random_number the random_number to set | ||||||
|  |  * @param console_id the console id to set | ||||||
|  |  */ | ||||||
|  | ResultCode SetConsoleUniqueId(u32 random_number, u64 console_id); | ||||||
|  | 
 | ||||||
|  | /**
 | ||||||
|  |  * Gets the console unique id from config savegame. | ||||||
|  |  * @returns the console unique id | ||||||
|  |  */ | ||||||
|  | u64 GetConsoleUniqueId(); | ||||||
|  | 
 | ||||||
| } // namespace CFG
 | } // namespace CFG
 | ||||||
| } // namespace Service
 | } // namespace Service
 | ||||||
|  |  | ||||||
		Loading…
	
	Add table
		Add a link
		
	
		Reference in a new issue
	
	 B3n30
						B3n30