Implement post /api/user endpoint

This commit is contained in:
Ethan O'Brien
2024-02-26 20:38:53 -06:00
parent 9f28840c77
commit f20e948f16
2 changed files with 43 additions and 1 deletions

View File

@ -20,6 +20,31 @@ pub fn user(req: HttpRequest) -> HttpResponse {
global::send(resp)
}
pub fn user_post(req: HttpRequest, body: String) -> HttpResponse {
let body = json::parse(&encryption::decrypt_packet(&body).unwrap()).unwrap();
let blank_header = HeaderValue::from_static("");
let key = req.headers().get("a6573cbe").unwrap_or(&blank_header).to_str().unwrap_or("");
let uid = req.headers().get("aoharu-user-id").unwrap_or(&blank_header).to_str().unwrap_or("");
let mut user = userdata::get_acc(key, uid);
let user_2 = userdata::get_acc_home(key, uid);
user["user"]["name"] = body["name"].clone();
user["user"]["friend_request_disabled"] = body["friend_request_disabled"].clone();
userdata::save_acc(key, uid, user.clone());
let resp = object!{
"code": 0,
"server_time": global::timestamp(),
"data": {
"user": user["user"].clone(),
"clear_mission_ids": user_2["clear_mission_ids"].clone()
}
};
global::send(resp)
}
pub fn initialize(req: HttpRequest, body: String) -> HttpResponse {
let body = json::parse(&encryption::decrypt_packet(&body).unwrap()).unwrap();
let blank_header = HeaderValue::from_static("");
@ -33,7 +58,20 @@ pub fn initialize(req: HttpRequest, body: String) -> HttpResponse {
user["user"]["guest_smile_master_card_id"] = id.into();
user["user"]["guest_cool_master_card_id"] = id.into();
user["user"]["guest_pure_master_card_id"] = id.into();
user["user"]["master_title_ids"][0] = id.into();
let id = body["master_character_id"].to_string();
let userr = &id[id.len() - 2..].parse::<i32>().unwrap();
let mut masterid = 3000000;
if id.starts_with("2") {
masterid += 9; //muse
} else if id.starts_with("3") {
masterid += 9 + 9; //aquors
} else if id.starts_with("4") {
masterid += 9 + 9 + 12; //nijigasaki
}
masterid += userr;
user["user"]["master_title_ids"][0] = masterid.into();
userdata::save_acc(key, uid, user.clone());