summaryrefslogtreecommitdiff
path: root/src/core/crypto/key_manager.cpp
diff options
context:
space:
mode:
authorGravatar bunnei2018-09-04 16:20:40 -0400
committerGravatar GitHub2018-09-04 16:20:40 -0400
commitfaa9e066aba320bcd38fd023ee58c6f9e1d3efdd (patch)
treec369b13af5a30698564ee54acbae639be4576482 /src/core/crypto/key_manager.cpp
parentMerge pull request #1238 from lioncash/explicit (diff)
parentmain: Only show DRD deprecation warning once (diff)
downloadyuzu-faa9e066aba320bcd38fd023ee58c6f9e1d3efdd.tar.gz
yuzu-faa9e066aba320bcd38fd023ee58c6f9e1d3efdd.tar.xz
yuzu-faa9e066aba320bcd38fd023ee58c6f9e1d3efdd.zip
Merge pull request #1178 from DarkLordZach/nsp
file_sys: Add Nintendo Submissions Package (NSP) file format
Diffstat (limited to 'src/core/crypto/key_manager.cpp')
-rw-r--r--src/core/crypto/key_manager.cpp16
1 files changed, 13 insertions, 3 deletions
diff --git a/src/core/crypto/key_manager.cpp b/src/core/crypto/key_manager.cpp
index f768533da..6f27f990b 100644
--- a/src/core/crypto/key_manager.cpp
+++ b/src/core/crypto/key_manager.cpp
@@ -231,18 +231,28 @@ void KeyManager::WriteKeyToFile(bool title_key, std::string_view keyname,
231} 231}
232 232
233void KeyManager::SetKey(S128KeyType id, Key128 key, u64 field1, u64 field2) { 233void KeyManager::SetKey(S128KeyType id, Key128 key, u64 field1, u64 field2) {
234 const auto iter = std::find_if( 234 if (s128_keys.find({id, field1, field2}) != s128_keys.end())
235 return;
236 if (id == S128KeyType::Titlekey) {
237 Key128 rights_id;
238 std::memcpy(rights_id.data(), &field2, sizeof(u64));
239 std::memcpy(rights_id.data() + sizeof(u64), &field1, sizeof(u64));
240 WriteKeyToFile(true, Common::HexArrayToString(rights_id), key);
241 }
242 const auto iter2 = std::find_if(
235 s128_file_id.begin(), s128_file_id.end(), 243 s128_file_id.begin(), s128_file_id.end(),
236 [&id, &field1, &field2](const std::pair<std::string, KeyIndex<S128KeyType>> elem) { 244 [&id, &field1, &field2](const std::pair<std::string, KeyIndex<S128KeyType>> elem) {
237 return std::tie(elem.second.type, elem.second.field1, elem.second.field2) == 245 return std::tie(elem.second.type, elem.second.field1, elem.second.field2) ==
238 std::tie(id, field1, field2); 246 std::tie(id, field1, field2);
239 }); 247 });
240 if (iter != s128_file_id.end()) 248 if (iter2 != s128_file_id.end())
241 WriteKeyToFile(id == S128KeyType::Titlekey, iter->first, key); 249 WriteKeyToFile(false, iter2->first, key);
242 s128_keys[{id, field1, field2}] = key; 250 s128_keys[{id, field1, field2}] = key;
243} 251}
244 252
245void KeyManager::SetKey(S256KeyType id, Key256 key, u64 field1, u64 field2) { 253void KeyManager::SetKey(S256KeyType id, Key256 key, u64 field1, u64 field2) {
254 if (s256_keys.find({id, field1, field2}) != s256_keys.end())
255 return;
246 const auto iter = std::find_if( 256 const auto iter = std::find_if(
247 s256_file_id.begin(), s256_file_id.end(), 257 s256_file_id.begin(), s256_file_id.end(),
248 [&id, &field1, &field2](const std::pair<std::string, KeyIndex<S256KeyType>> elem) { 258 [&id, &field1, &field2](const std::pair<std::string, KeyIndex<S256KeyType>> elem) {