pb: 5 builds
All checks were successful
continuous-integration/drone/push Build is passing

This commit is contained in:
nyyu 2021-10-31 09:22:49 +01:00
parent 3fade08679
commit 71512c08e6
3 changed files with 34 additions and 17 deletions

View file

@ -42,7 +42,7 @@ struct Stats {
kills: u32, kills: u32,
deaths: u32, deaths: u32,
wins: u32, wins: u32,
assists: u32 assists: u32,
} }
#[derive(Deserialize, Debug)] #[derive(Deserialize, Debug)]
@ -173,7 +173,8 @@ impl DataSource for CGGDataSource {
Stat { Stat {
win_rate: (champ.stats.wins as f64 / champ.stats.games as f64) * 100f64, win_rate: (champ.stats.wins as f64 / champ.stats.games as f64) * 100f64,
games: champ.stats.games, games: champ.stats.games,
kda: (champ.stats.kills + champ.stats.assists) as f64 / champ.stats.deaths as f64, kda: (champ.stats.kills + champ.stats.assists) as f64
/ champ.stats.deaths as f64,
patch: champ.patch.to_owned(), patch: champ.patch.to_owned(),
}, },
)); ));

View file

@ -10,7 +10,6 @@ pub struct MSDataSource;
const CHAMP_PATTERN: &str = " href=\"https://www.metasrc.com/5v5/champion/"; const CHAMP_PATTERN: &str = " href=\"https://www.metasrc.com/5v5/champion/";
impl DataSource for MSDataSource { impl DataSource for MSDataSource {
fn get_alias(&self) -> &str { fn get_alias(&self) -> &str {
"MS" "MS"
} }

View file

@ -62,26 +62,43 @@ impl DataSource for PBDataSource {
let mut builds = vec![]; let mut builds = vec![];
let rep = client let rep = client
.get(format!("https://www.probuilds.net/ajax/gamesLive?limit=1&sort=gameDate-desc&championId={}&olderThan=0&lane=&region=", champ.key).as_str()) .get(format!("https://www.probuilds.net/ajax/gamesLive?limit=5&sort=gameDate-desc&championId={}&olderThan=0&lane=&region=", champ.key).as_str())
.set("Accept", "application/json") .set("Accept", "application/json")
.call(); .call();
if let Ok(page) = rep { if let Ok(page) = rep {
let str = page.into_string().unwrap(); let rep: Vec<String> = serde_json::from_str(&page.into_string().unwrap()).unwrap();
let mut items = vec![];
let mut build = &str[str.find("'items'").unwrap()..];
while build.contains("items") {
let pos = build.find("data-id=").unwrap();
build = &build[pos + 10..];
let end = build.find('\\').unwrap();
items.push(&build[..end]);
build = &build[end + 20..];
}
builds.push((positions[0].to_owned(), vec![json!({ let mut blocks = vec![];
for build in rep {
let pos = build.find("/players").unwrap();
let tmp = &build[pos..];
let name = &tmp[tmp.find(">").unwrap() + 1..tmp.find("<").unwrap()];
let mut items = vec![];
let mut build = &build[build.find("'items'").unwrap()..];
while build.contains("items") {
let pos = build.find("data-id=").unwrap();
build = &build[pos + 10..];
let end = build.find('"').unwrap();
items.push(&build[..end]);
build = &build[end + 20..];
}
blocks.push(json!({
"items": items.iter().map(|x| json!({"id": x.to_string(), "count": 1})).collect::<Vec<Value>>(), "items": items.iter().map(|x| json!({"id": x.to_string(), "count": 1})).collect::<Vec<Value>>(),
"type": "Set" "type": format!("{}", name)}));
})], Stat{win_rate:0.0,games:1,kda:0.0,patch:"".to_string()})); }
builds.push((
positions[0].to_owned(),
blocks,
Stat {
win_rate: 0.0,
games: 1,
kda: 0.0,
patch: "".to_string(),
},
));
} }
builds builds
} }