fix cgg
All checks were successful
continuous-integration/drone/push Build is passing

This commit is contained in:
nyyu 2021-10-30 11:54:32 +02:00
parent a9ea40f44a
commit 3fade08679

View file

@ -3,7 +3,6 @@ use lazy_static::lazy_static;
use log::error; use log::error;
use serde_derive::Deserialize; use serde_derive::Deserialize;
use serde_json::{json, Value}; use serde_json::{json, Value};
use std::collections::HashMap;
use std::sync::Mutex; use std::sync::Mutex;
use crate::data_source::{DataSource, Stat}; use crate::data_source::{DataSource, Stat};
@ -39,6 +38,11 @@ struct Stats {
most_common_core_builds: Build, most_common_core_builds: Build,
most_common_big_item_builds: Build, most_common_big_item_builds: Build,
most_common_skills: Build, most_common_skills: Build,
games: u32,
kills: u32,
deaths: u32,
wins: u32,
assists: u32
} }
#[derive(Deserialize, Debug)] #[derive(Deserialize, Debug)]
@ -48,25 +52,8 @@ struct Build {
games: u32, games: u32,
} }
#[derive(Deserialize, Debug, Clone)]
struct ChampStat {
champion_id: Option<u32>,
stats: Option<Info>,
matchups: Option<Vec<Info>>,
#[serde(rename = "winRate")]
win_rate: Option<f64>,
games: Option<u32>,
kda: Option<f64>,
}
#[derive(Deserialize, Debug, Clone)]
struct Info {
id: String,
}
lazy_static! { lazy_static! {
static ref CHAMPIONS_REPORT: Mutex<Vec<ChampionReport>> = Mutex::new(Vec::new()); static ref CHAMPIONS_REPORT: Mutex<Vec<ChampionReport>> = Mutex::new(Vec::new());
static ref CHAMPIONS_STATS: Mutex<HashMap<String, ChampStat>> = Mutex::new(HashMap::new());
} }
pub struct CGGDataSource; pub struct CGGDataSource;
@ -120,17 +107,6 @@ impl DataSource for CGGDataSource {
serde_json::from_str(&extract_json("window.__PRELOADED_STATE__ = ", page)) serde_json::from_str(&extract_json("window.__PRELOADED_STATE__ = ", page))
.unwrap(); .unwrap();
let champs_stats: HashMap<String, ChampStat> = serde_json::from_str(&extract_json(
"window.__FLASH_CMS_APOLLO_STATE__ = ",
page,
))
.unwrap();
for entry in champs_stats.iter() {
CHAMPIONS_STATS
.lock()
.unwrap()
.insert(entry.0.to_owned(), entry.1.to_owned());
}
for champ in &datas.lol.champions_report { for champ in &datas.lol.champions_report {
let id = champ.champion_id; let id = champ.champion_id;
if champions.contains_key(&id) { if champions.contains_key(&id) {
@ -191,28 +167,18 @@ impl DataSource for CGGDataSource {
), ),
]; ];
let mut key: String = String::new();
let champs_stats = CHAMPIONS_STATS.lock().unwrap();
for val in champs_stats.values() {
if val.champion_id.is_some() && val.champion_id.unwrap() == champ.champion_id {
key = val.stats.as_ref().unwrap().id.to_owned();
}
}
if let Some(stat) = champs_stats.get(&key) {
data.push(( data.push((
position.to_owned(), position.to_owned(),
blocks, blocks,
Stat { Stat {
win_rate: stat.win_rate.unwrap(), win_rate: (champ.stats.wins as f64 / champ.stats.games as f64) * 100f64,
games: stat.games.unwrap(), games: champ.stats.games,
kda: stat.kda.unwrap(), kda: (champ.stats.kills + champ.stats.assists) as f64 / champ.stats.deaths as f64,
patch: champ.patch.to_owned(), patch: champ.patch.to_owned(),
}, },
)); ));
} }
} }
}
data data
} }
} }