diff options
Diffstat (limited to 'src/core/crypto/key_manager.cpp')
| -rw-r--r-- | src/core/crypto/key_manager.cpp | 16 |
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 | ||
| 233 | void KeyManager::SetKey(S128KeyType id, Key128 key, u64 field1, u64 field2) { | 233 | void 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 | ||
| 245 | void KeyManager::SetKey(S256KeyType id, Key256 key, u64 field1, u64 field2) { | 253 | void 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) { |