Key replacement

This commit is contained in:
Benj
2022-07-06 19:56:37 +08:00
committed by lilmayofuksu
parent 936c533ff8
commit 27d7c32a73
4 changed files with 72 additions and 43 deletions

View File

@@ -0,0 +1 @@
<RSAKeyValue><Modulus>AMW28dptX3h8q0O4z/vJrQxf6cmC6yVilgHRL98GazrYzmc3ixj87JpHIJ3IKEYV+HU/tYrUjEfY/ZtPzsLB9lKBelN9i8QjkFkA9QDICGYwJCXibxU67Z/HzENe9NQpG2i01SI0TJU8PJDV7zQPwPVGraIg5ouExRupq8UymaSHEyJ7zxKZCtgO0LKdROLJBSvI5srMu7kYTGmB7T07Ab8T9M595YSgd1vh06qZ3nsF1h4wg3y+zW28vdY28+RCj2V1i7oVyL0dQruLYq7qK8FycZl2j9R0GaJ8rRAjVP1Dsz+hjS3atHhQxOG9OFo6d/euedRvfWIhT9p6h1SeTjE=</Modulus><Exponent>AQAB</Exponent></RSAKeyValue>

View File

@@ -0,0 +1,7 @@
<RSAKeyValue>
<Exponent>AQAB</Exponent>
<Modulus>yytg/H9lz7Lm0XcA8LMqIyXPVNApYTcSepT4VDLB4qqqFC3s
/Huv8vN7zA/P4uoREIu8KMenADFk7uwrZSxoMWwJgn6A7sbAt1cqAaUXB
9J4NzhL0x3AFTiHEQbw86hRvm2VGkbA5sWnr0NZw8SGBBY+EODwNIt51G
dBA7eoUQU=</Modulus>
</RSAKeyValue>

View File

@@ -1,18 +1,21 @@
use core::ffi::c_void;
use std::fs::File;
use std::io::Read;
use std::io::Write;
use libloading::os::windows::Library;
use libloading::os::windows::Symbol;
use regex::Regex;
use std::fs::File;
use std::io::Read;
use std::io::Write;
fn dll_decrypt_global_metadata(data : *mut u8, size : u64) -> Result<*const c_void, Box<dyn std::error::Error>> {
fn dll_decrypt_global_metadata(
data: *mut u8,
size: u64,
) -> Result<*const c_void, Box<dyn std::error::Error>> {
unsafe {
// Load DLL
let lib = Library::new("mhycrypto.dll")?;
// Load function and call it
let func : Symbol<unsafe extern fn(*mut u8, u64) -> *const c_void> = lib.get_ordinal(0x1)?;
let func: Symbol<unsafe extern "C" fn(*mut u8, u64) -> *const c_void> = lib.get_ordinal(0x1)?;
let decrypted_data = func(data, size);
// Close DLL and return result
@@ -21,13 +24,16 @@ fn dll_decrypt_global_metadata(data : *mut u8, size : u64) -> Result<*const c_vo
}
}
fn dll_encrypt_global_metadata(data : *mut u8, size : u64) -> Result<*const c_void, Box<dyn std::error::Error>> {
fn dll_encrypt_global_metadata(
data: *mut u8,
size: u64,
) -> Result<*const c_void, Box<dyn std::error::Error>> {
unsafe {
// Load DLL
let lib = Library::new("mhycrypto.dll")?;
// Load function and call it
let func : Symbol<unsafe extern fn(*mut u8, u64) -> *const c_void> = lib.get_ordinal(0x2)?;
let func: Symbol<unsafe extern "C" fn(*mut u8, u64) -> *const c_void> = lib.get_ordinal(0x2)?;
let encrypted_data = func(data, size);
// Close DLL and return result
@@ -42,17 +48,11 @@ pub fn patch_metadata(metadata_folder: &str) {
println!("Patching metadata file: {}", metadata_file);
let decrypted: Vec<u8> = decrypt_metadata(metadata_file);
//write decrypted to file
let mut file = File::create(&(metadata_folder.to_owned() + "\\decrypted-metadata.dat")).unwrap();
file.write_all(&decrypted).unwrap();
let modified = replace_keys(&decrypted);
replace_rsa_key(&decrypted);
/*if decrypted != Vec::new() {
} else {
// error
}*/
//write modfied to file
let mut file = File::create(&(metadata_folder.to_owned() + "\\modified-metadata.dat")).unwrap();
file.write_all(&modified).unwrap();
}
fn decrypt_metadata(file_path: &str) -> Vec<u8> {
@@ -84,7 +84,9 @@ fn decrypt_metadata(file_path: &str) -> Vec<u8>{
}
}
fn replace_rsa_key(data: &Vec<u8>) {
fn replace_keys(data: &Vec<u8>) -> Vec<u8> {
let mut new_data = String::new();
unsafe {
let data_str = String::from_utf8_unchecked(data.to_vec());
@@ -94,21 +96,39 @@ fn replace_rsa_key(data: &Vec<u8>) {
// dispatch key is index 3
// password key is index 2
//println!("Found {} RSA Key(s)", matches.count());
for (i, rmatch) in matches.enumerate() {
let key = rmatch.as_str();
println!("{} - RSA Key {}", i, key);
println!("\n");
if i == 2 {
println!("Replacing password key");
new_data = replace_rsa_key(&data_str, &key, "passwordKey.txt");
} else if i == 3 {
println!("Replacing dispatch key");
new_data = replace_rsa_key(&new_data, &key, "dispatchKey.txt");
}
}
}
return new_data.as_bytes().to_vec();
}
fn replace_rsa_key(old_data: &str, to_replace: &str, file_name: &str) -> String {
// Read dispatch key file
unsafe {
let mut new_key_file = match File::open(&("keys/".to_owned() + file_name)) {
Ok(file) => file,
Err(e) => {
println!("Failed to open keys/{}: {}", file_name, e);
return String::new();
}
};
let mut key_data = Vec::new();
new_key_file.read_to_end(&mut key_data).unwrap();
let new_key = String::from_utf8_unchecked(key_data.to_vec());
/*if matches.count() < 1 {
println!("No RSA keys found");
return Vec::new();
}*/
// Replace old key with new key
return old_data.replace(to_replace, &new_key);
}
}
/*let mut file = match OpenOptions::new().write(true).create(true).open(&(file_location.to_owned() + "\\decrypted_metadata.dat")) {

View File

@@ -56,6 +56,7 @@
},
"resources": [
"lang/*.json",
"keys/*",
"./mhycrypto.dll"
],
"targets": "all",