ms: improve
All checks were successful
continuous-integration/drone/push Build is passing

This commit is contained in:
nyyu 2021-10-31 10:12:53 +01:00
parent 0982c30f7a
commit d854da599f
4 changed files with 54 additions and 34 deletions

4
Cargo.lock generated
View file

@ -210,9 +210,9 @@ checksum = "e2abad23fbc42b3700f2f279844dc832adb2b2eb069b2df918f455c4e18cc646"
[[package]] [[package]]
name = "libc" name = "libc"
version = "0.2.105" version = "0.2.106"
source = "registry+https://github.com/rust-lang/crates.io-index" source = "registry+https://github.com/rust-lang/crates.io-index"
checksum = "869d572136620d55835903746bcb5cdc54cb2851fd0aeec53220b4bb65ef3013" checksum = "a60553f9a9e039a333b4e9b20573b9e9b9c0bb3a11e201ccc48ef4283456d673"
[[package]] [[package]]
name = "log" name = "log"

View file

@ -3,7 +3,7 @@ use crate::Champion;
use indexmap::IndexMap; use indexmap::IndexMap;
use log::{error, info}; use log::{error, info};
use serde_derive::{Deserialize, Serialize}; use serde_derive::{Deserialize, Serialize};
use serde_json::Value; use serde_json::{json, Value};
use std::fs; use std::fs;
use std::path::Path; use std::path::Path;
@ -19,14 +19,14 @@ struct ItemSet {
blocks: Vec<Value>, blocks: Vec<Value>,
} }
#[derive(Serialize, Deserialize, Debug)] #[derive(Serialize, Deserialize)]
pub struct Build { pub struct Build {
#[serde(rename = "type")] #[serde(rename = "type")]
pub type_: String, pub type_: String,
pub items: Vec<Item>, pub items: Vec<Item>,
} }
#[derive(Serialize, Deserialize, Debug)] #[derive(Serialize, Deserialize)]
pub struct Item { pub struct Item {
pub id: String, pub id: String,
pub count: u8, pub count: u8,
@ -50,6 +50,13 @@ pub trait DataSource {
champion: &Champion, champion: &Champion,
) -> IndexMap<u32, Vec<String>>; ) -> IndexMap<u32, Vec<String>>;
fn make_item_set(&self, items: Vec<&str>, label: String) -> Value {
json!({
"items": items.iter().map(|x| json!({"id": x.to_string(), "count": 1})).collect::<Vec<Value>>(),
"type": label
})
}
fn get_champ_data_with_win_pourcentage( fn get_champ_data_with_win_pourcentage(
&self, &self,
champ: &ChampInfo, champ: &ChampInfo,

View file

@ -1,5 +1,5 @@
use indexmap::IndexMap; use indexmap::IndexMap;
use serde_json::{json, Value}; use serde_json::Value;
use crate::data_source::{DataSource, Stat}; use crate::data_source::{DataSource, Stat};
use crate::ChampInfo; use crate::ChampInfo;
@ -44,7 +44,7 @@ impl DataSource for MSDataSource {
let id = champion.data.get(key).unwrap().key.parse::<u32>().unwrap(); let id = champion.data.get(key).unwrap().key.parse::<u32>().unwrap();
champs.insert(id, vec![role.to_string()]); champs.insert(id, vec![role.to_uppercase()]);
let next = page[p..].find(CHAMP_PATTERN); let next = page[p..].find(CHAMP_PATTERN);
if let Some(n) = next { if let Some(n) = next {
@ -65,41 +65,56 @@ impl DataSource for MSDataSource {
) -> Vec<(String, Vec<Value>, Stat)> { ) -> Vec<(String, Vec<Value>, Stat)> {
let mut builds = vec![]; let mut builds = vec![];
let page = client let rep = client
.get( .get(
format!( format!(
"https://www.metasrc.com/5v5/champion/{}/{}", "https://www.metasrc.com/5v5/champion/{}/{}",
champ.id.to_lowercase(), champ.id.to_lowercase(),
positions[0] positions[0].to_lowercase()
) )
.as_str(), .as_str(),
) )
.call() .call();
.unwrap() if let Ok(p) = rep {
.into_string() let page = p.into_string().unwrap();
.unwrap();
let mut items = vec![]; let mut pos = page.find("Patch ").unwrap();
let patch = &page[pos + 6..pos + 11];
let mut pos: Option<usize> = page.find("/item/"); pos = page.find("Win Rate:").unwrap();
while let Some(mut p) = pos { let win_rate: f64 = (&page[pos + 26..pos + 31]).parse().unwrap();
p += 6;
let i = &page[p..p + page[p..].find('.').unwrap()];
items.push(i); pos = page.find("KDA:").unwrap();
let kda: f64 = (&page[pos + 21..pos + 25]).parse().unwrap();
let next = page[p..].find("/item/"); let mut items = vec![];
if let Some(n) = next {
pos = Some(p + n); let mut pos: Option<usize> = page.find("/item/");
} else { while let Some(mut p) = pos {
pos = None; p += 6;
let i = &page[p..p + page[p..].find('.').unwrap()];
items.push(i);
let next = page[p..].find("/item/");
if let Some(n) = next {
pos = Some(p + n);
} else {
pos = None;
}
} }
}
builds.push((positions[0].to_owned(), vec![json!({ builds.push((
"items": items.iter().map(|x| json!({"id": x.to_string(), "count": 1})).collect::<Vec<Value>>(), positions[0].to_owned(),
"type": "Set" vec![self.make_item_set(items, "Set".to_owned())],
})], Stat{win_rate:0.0,games:1,kda:0.0,patch:"".to_string()})); Stat {
win_rate,
games: 1,
kda,
patch: patch.to_owned(),
},
));
}
builds builds
} }

View file

@ -1,6 +1,6 @@
use indexmap::IndexMap; use indexmap::IndexMap;
use serde_derive::Deserialize; use serde_derive::Deserialize;
use serde_json::{json, Value}; use serde_json::Value;
use crate::data_source::{DataSource, Stat}; use crate::data_source::{DataSource, Stat};
use crate::ChampInfo; use crate::ChampInfo;
@ -73,7 +73,7 @@ impl DataSource for PBDataSource {
for build in rep { for build in rep {
let pos = build.find("/players").unwrap(); let pos = build.find("/players").unwrap();
let tmp = &build[pos..]; let tmp = &build[pos..];
let name = &tmp[tmp.find(">").unwrap() + 1..tmp.find("<").unwrap()]; let name = &tmp[tmp.find('>').unwrap() + 1..tmp.find('<').unwrap()];
let mut items = vec![]; let mut items = vec![];
let mut build = &build[build.find("'items'").unwrap()..]; let mut build = &build[build.find("'items'").unwrap()..];
@ -85,9 +85,7 @@ impl DataSource for PBDataSource {
build = &build[end + 20..]; build = &build[end + 20..];
} }
blocks.push(json!({ blocks.push(self.make_item_set(items, name.to_string()));
"items": items.iter().map(|x| json!({"id": x.to_string(), "count": 1})).collect::<Vec<Value>>(),
"type": format!("{}", name)}));
} }
builds.push(( builds.push((
positions[0].to_owned(), positions[0].to_owned(),