nsig function extraction works!

This commit is contained in:
techmetx11 2024-04-29 06:47:17 +01:00
parent 33a33f4060
commit b601571cff
No known key found for this signature in database
GPG key ID: 20E0C88A0E7E5AF2
3 changed files with 51 additions and 12 deletions

View file

@ -8,5 +8,3 @@ pub static REGEX_PLAYER_ID: &Lazy<Regex> = regex!("\\/s\\/player\\/([0-9a-f]{8})
pub static NSIG_FUNCTION_ARRAY: &Lazy<Regex> = regex!(
"\\.get\\(\"n\"\\)\\)&&\\([a-zA-Z0-9$_]=([a-zA-Z0-9$_]+)(?:\\[(\\d+)])?\\([a-zA-Z0-9$_]\\)"
);
pub static NSIG_FUNCTION_BODY: &Lazy<Regex> =
regex!("=\\s*function([\\S\\s]*?\\}\\s*return [\\w$]+?\\.join\\(\"\"\\)\\s*\\};)");

View file

@ -17,20 +17,22 @@ impl From<u8> for JobOpcode {
match value {
0x00 => Self::ForceUpdate,
0x01 => Self::DecryptNSignature,
// make debugging easier
b'a' => Self::ForceUpdate,
_ => Self::UnknownOpcode,
}
}
}
pub struct PlayerInfo {
nsig_function_code: Vec<u8>,
nsig_function_code: String,
player_id: u32,
}
pub struct JavascriptInterpreter {
js_runtime: AsyncRuntimeWrapper,
nsig_context: AsyncContextWrapper,
nsig_function_name: String,
player_id: u32,
}
@ -70,7 +72,6 @@ impl JavascriptInterpreter {
JavascriptInterpreter {
js_runtime: AsyncRuntimeWrapper(js_runtime),
nsig_context: AsyncContextWrapper(nsig_context),
nsig_function_name: Default::default(),
player_id: 0,
}
}
@ -89,10 +90,9 @@ impl GlobalState {
.get();
let mut runtime_vector: Vec<Arc<JavascriptInterpreter>> =
Vec::with_capacity(number_of_runtimes);
runtime_vector
.iter_mut()
.for_each(|a| *a = Arc::new(JavascriptInterpreter::new()));
for n in 0..number_of_runtimes {
runtime_vector.push(Arc::new(JavascriptInterpreter::new()));
}
// Make a clone of the vector, this will clone all the values inside (Arc)
let mut runtime_vector2: Vec<Arc<JavascriptInterpreter>> =
Vec::with_capacity(number_of_runtimes);
@ -125,7 +125,7 @@ pub async fn process_fetch_update(state: Arc<GlobalState>) {
let player_id: u32 = u32::from_str_radix(player_id_str, 16).unwrap();
let current_player_info = global_state.player_info.lock().await;
let mut current_player_info = global_state.player_info.lock().await;
let current_player_id = current_player_info.player_id;
// release the mutex for other tasks
drop(current_player_info);
@ -150,7 +150,12 @@ pub async fn process_fetch_update(state: Arc<GlobalState>) {
let nsig_function_array = NSIG_FUNCTION_ARRAY.captures(&player_javascript).unwrap();
let nsig_array_name = nsig_function_array.get(1).unwrap().as_str();
let nsig_array_value = usize::from_str_radix(nsig_function_array.get(2).unwrap().as_str(), 10);
let nsig_array_value = nsig_function_array
.get(2)
.unwrap()
.as_str()
.parse::<usize>()
.unwrap();
let mut nsig_array_context_regex: String = String::new();
nsig_array_context_regex += "var ";
@ -164,5 +169,40 @@ pub async fn process_fetch_update(state: Arc<GlobalState>) {
return;
}
};
let array_content = nsig_array_context
.captures(&player_javascript)
.unwrap()
.get(1)
.unwrap()
.as_str()
.split(",");
let array_values: Vec<&str> = array_content.collect();
let nsig_function_name = array_values.get(nsig_array_value).unwrap();
// Extract nsig function code
let mut nsig_function_code_regex_str: String = String::new();
nsig_function_code_regex_str += nsig_function_name;
nsig_function_code_regex_str +=
"=\\s*function([\\S\\s]*?\\}\\s*return [\\w$]+?\\.join\\(\"\"\\)\\s*\\};)";
let nsig_function_code_regex = Regex::new(&nsig_function_code_regex_str).unwrap();
let mut nsig_function_code = String::new();
nsig_function_code += "decrypt_nsig = function";
nsig_function_code += nsig_function_code_regex
.captures(&player_javascript)
.unwrap()
.get(1)
.unwrap()
.as_str();
current_player_info = global_state.player_info.lock().await;
current_player_info.player_id = player_id;
current_player_info.nsig_function_code = nsig_function_code;
println!("{}", current_player_info.nsig_function_code);
}
pub async fn process_decrypt_n_signature(_state: Arc<GlobalState>, _sig: String) {}

View file

@ -5,7 +5,7 @@ use consts::DEFAULT_SOCK_PATH;
use jobs::{process_decrypt_n_signature, process_fetch_update, GlobalState, JobOpcode};
use std::{env::args, sync::Arc};
use tokio::{
io::{AsyncReadExt, BufReader},
io::{AsyncBufReadExt, AsyncReadExt, BufReader},
net::{UnixListener, UnixStream},
};
@ -46,6 +46,7 @@ async fn main() {
async fn process_socket(state: Arc<GlobalState>, socket: UnixStream) {
let mut bufreader = BufReader::new(socket);
bufreader.fill_buf().await;
loop {
let opcode_byte: u8 = break_fail!(bufreader.read_u8().await);