Implement /api/mission/clear

This commit is contained in:
Ethan O'Brien 2024-04-08 16:15:20 -05:00
parent 15df55dd34
commit 2115bbb08b
3 changed files with 42 additions and 6 deletions

View file

@ -117,6 +117,9 @@ async fn live_clearrate(req: HttpRequest) -> HttpResponse { router::live::clearr
#[get("/api/mission")] #[get("/api/mission")]
async fn mission(req: HttpRequest) -> HttpResponse { router::mission::mission(req) } async fn mission(req: HttpRequest) -> HttpResponse { router::mission::mission(req) }
#[get("/api/mission/clear")]
async fn mission_clear(req: HttpRequest, body: String) -> HttpResponse { router::mission::clear(req, body) }
#[get("/api/home")] #[get("/api/home")]
async fn home(req: HttpRequest) -> HttpResponse { router::home::home(req) } async fn home(req: HttpRequest) -> HttpResponse { router::home::home(req) }
@ -213,6 +216,7 @@ async fn main() -> std::io::Result<()> {
.service(lottery) .service(lottery)
.service(friend) .service(friend)
.service(mission) .service(mission)
.service(mission_clear)
.service(home) .service(home)
.service(start_assethash) .service(start_assethash)
.service(user) .service(user)

View file

@ -2,17 +2,50 @@ use json;
use json::object; use json::object;
use crate::router::global; use crate::router::global;
use actix_web::{HttpResponse, HttpRequest}; use actix_web::{HttpResponse, HttpRequest};
//use crate::router::userdata; use crate::router::userdata;
use crate::encryption;
pub fn mission(_req: HttpRequest) -> HttpResponse { pub fn mission(req: HttpRequest) -> HttpResponse {
//let key = global::get_login(req.headers()); let key = global::get_login(req.headers(), "");
//let user = userdata::get_acc(&key); let missions = userdata::get_acc_missions(&key);
let resp = object!{ let resp = object!{
"code": 0, "code": 0,
"server_time": global::timestamp(), "server_time": global::timestamp(),
"data": { "data": {
"mission_list": [] "mission_list": missions
}
};
global::send(resp)
}
pub fn clear(req: HttpRequest, body: String) -> HttpResponse {
let key = global::get_login(req.headers(), &body);
let mut missions = userdata::get_acc_missions(&key);
let body = json::parse(&encryption::decrypt_packet(&body).unwrap()).unwrap();
for (_i, id) in body["master_mission_ids"].members().enumerate() {
for (i, mission) in missions.members().enumerate() {
if mission["master_mission_id"].to_string() == id.to_string() {
//I think this is all?
missions[i]["progress"] = (1).into();
break;
}
}
}
userdata::save_acc_missions(&key, missions);
let resp = object!{
"code": 0,
"server_time": global::timestamp(),
"data": {
"clear_mission_ids": body["master_mission_ids"].clone()
}
};
global::send(resp)
}
} }
}; };
global::send(resp) global::send(resp)

View file

@ -232,7 +232,6 @@ pub fn detail(_req: HttpRequest, body: String) -> HttpResponse {
to_push["user"].remove("ss_user_id"); to_push["user"].remove("ss_user_id");
to_push["user"].remove("birthday"); to_push["user"].remove("birthday");
user_detail_list.push(to_push).unwrap(); user_detail_list.push(to_push).unwrap();
} }
let resp = object!{ let resp = object!{
"code": 0, "code": 0,